create-react-app 入门教程
Create React App
是 FaceBook 的 React 团队官方出的一个构建 React
单页面应用的脚手架工具。它本身集成了 Webpack
,并配置了一系列内置的 loader
和默认的 npm 的脚本,可以很轻松的实现零配置就可以快速开发 React 的应用。
Quick Start(快速入门)
全局安装
首先确保你电脑上安装最新的
# 全局安装
npm install -g create-react-app
# 构建一个 my-app 的项目
npx create-react-app my-app
cd my-app
# 启动编译当前的 React 项目,并自动打开 http://localhost:3000/
npm start
以上命令执行完成后,则自动打开: http://localhost:3000/
如果你不能确保最新版本,可以先尝试卸载:
npm uninstall -g create-react-app
,然后再全局安装。
构建 React 项目的其他方式
- npm
# npm init <initializer> is available in npm 6+
npm init react-app my-app
- Yarn
# yarn create is available in Yarn 0.25+
yarn create react-app my-app
项目目录
项目的默认目录:
├── package.json
├── public # 这个是 webpack 的配置的静态目录
│ ├── favicon.ico
│ ├── index.html # 默认是单页面应用,这个是最终的 html 的基础模板
│ └── manifest.json
├── src
│ ├── App.css # App 根组件的 css
│ ├── App.js # App 组件代码
│ ├── App.test.js
│ ├── index.css # 启动文件样式
│ ├── index.js # 启动的文件(开始执行的入口)!!!!
│ ├── logo.svg
│ └── serviceWorker.js
└── yarn.lock
默认的 npm 的脚本
启动开发
npm start
# or
yarn start
启动测试
npm test
#or
yarn test
构建生产版本
npm run build
#or
yarn build
解压默认的 webpack 配置到配置文件中
npm run eject
启用 sass
react-scripts@2.0.0 以上版本才适用。
安装依赖
要使用 Sass 必须首先安装 node-sass
$ npm install node-sass --save
$ # or
$ yarn add node-sass
安装完之后,我们就可以直接把原来的 CSS 文件后缀直接改为 .scss
或者 .sass
,然后组件中导入的文件不再是 css 文件而给我 scss 文件即可。
import React, {Component} from 'react';
import store from './Store/Index';
import {AddNumCreator, MinusNumCreator} from './Store/ActionCreaters';
import './App.scss';
class App extends Component {
render() {
return (
<div className="App">
<header className="App-header">
<h1>潇洒</h1>
</header>
</div>
);
}
}
export default App;
在 sass 文件中引入其他 sass 文件
- 引入 src 中的 scss 文件
@import 'styles/_colors.scss';
- 引入
node_modules
中的样式:@import '~nprogress/nprogress';
~ 就代表: node_modules
CSS Modules 支持
导入 CSS 文件或者 Sass 文件的时候,可以用一个变量接收一下返回值。那么就可以直接通过它来访问 CSS 或者 Sass 中的内部样式类了。比如:
- Button.module.css
.error {
background-color: red;
}
- Button.js
import React, { Component } from 'react';
import styles from './Button.module.css'; // Import css modules stylesheet as styles
class Button extends Component {
render() {
// reference as a js object
return <button className={styles.error}>Error Button</button>;
}
}
结果:
<!-- This button has red background -->
<button class="Button_error_ax7yz">Error Button</button>
了解更多关于 CSS 模块化
公共目录
公共目录里面的内容不会被 webpack 进行处理,仅仅会拷贝到最终生成的项目的根目录下。
HTML 模板修改
在 public
目录中有个 index.html
是单页面应用的基本模板,所有 react 生成的代码都会注入到此 HTML 中。所以此处可以添加一些 cdn 脚本或者全局的 html。
添加全局的资源(图片、字体、svg、视频等)
在公共目录下,你可以放字体文件、图片、svg 等文件,访问这些文件最好添加 %PUBLIC_URL%
作为根目录。
<link rel="shortcut icon" href="%PUBLIC_URL%/favicon.ico">
环境变量
巧妙的使用环境变量可以帮我们在项目中区分开生产环境还是编译环境,从而执行不同的代码。
命令行直接添加环境变量
- Windows (cmd.exe)
set "REACT_APP_NOT_SECRET_CODE=abcdef" && npm start
- Windows (Powershell)
($env:REACT_APP_NOT_SECRET_CODE = "abcdef") -and (npm start)
- Linux, macOS (Bash)
REACT_APP_NOT_SECRET_CODE=abcdef npm start
添加自定义环境变量文件 .env
项目根目录下创建 .env
文件,文件内部添加 key=value
的配置可以直接应用于项目的编译中。
REACT_APP_NOT_SECRET_CODE=abcdef
Note: 如果创建自定义的环境变量必须以
REACT_APP_
开头.
在项目中使用环境变量
在项目中可以直接用 process.env.XXX
访问我们的自定义的环境变量。比如:
- js 中使用
render() {
return (
<div>
<small>You are running this application in <b>{process.env.NODE_ENV}</b> mode.</small>
<form>
<input type="hidden" defaultValue={process.env.REACT_APP_NOT_SECRET_CODE} />
</form>
</div>
);
}
再比如:判断是否是生产环境
if (process.env.NODE_ENV !== 'production') {
analytics.disable();
}
- HTML 中使用
<title>%REACT_APP_WEBSITE_NAME%</title>
配合 TypeScript
第一种方式:创建项目的时候直接配置好 TypeScript
.
npx create-react-app my-app --typescript
#or
yarn create react-app my-app --typescript
第二种方式:为现有的 React 项目添加 TypeScript
npm install --save typescript @types/node @types/react @types/react-dom @types/jest
# or
yarn add typescript @types/node @types/react @types/react-dom @types/jest
配置代理
package.json
配置代理
配置简单代理,直接在 package.json 文件中添加 proxy 节点即可:
{
...
"proxy": "http://localhost:4000",
...
}
自定义配置代理
第一步:安装 http-proxy-middleware
$ npm install http-proxy-middleware --save
$ # or
$ yarn add http-proxy-middleware
第二步:创建: src/setupProxy.js
添加如下内容:
const proxy = require('http-proxy-middleware');
module.exports = function(app) {
app.use(proxy('/api', { target: 'http://localhost:5000/' }));
};
Visual Studio Code 配置 React 开发环境
React 集成 VSCode 测试
第一步: 首先安装: Debugger for Chrome
插件。 第二步: 项目根目录下创建 .vscode
文件夹。 第三步:创建 launch.json
文件 文件内容:
{
"version": "0.2.0",
"configurations": [
{
"name": "Chrome",
"type": "chrome",
"request": "launch",
"url": "http://localhost:3000",
"webRoot": "${workspaceFolder}/src",
"sourceMapPathOverrides": {
"webpack:///src/*": "${webRoot}/*"
}
}
]
}
此时可以 F5
直接启动测试了。
插件
- Reactjs code snippets
- Prettier - Code formatter
- ES7 React/Redux/GraphQL/React-Native snippets
- eslint
HTTPS 托管静态站
有时候需要用 HTTPS 进行调试相关结构,所以需要把静态站也做成 HTTPS 的,那么以下配置:
配置 HTTPS
的环境变量为 true
然后再用 npm start
启动 dev server
就是 HTTPS 的了。
- Windows (cmd.exe)
set HTTPS=true&&npm start
- Windows (Powershell)
($env:HTTPS = "true") -and (npm start)
- Linux, macOS (Bash)
HTTPS=true npm start
浏览器可能有安全警告,不用管,直接测试,enjoy it!
分析包结构的大小
Source map explorer
可以帮助我们分析代码最终打包的 bundles
的代码来自哪里,
安装:
npm install --save source-map-explorer
#or
yarn add source-map-explorer
添加分析脚本到 package.json
的 scripts
中:
"scripts": {
+ "analyze": "source-map-explorer build/static/js/main.*",
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test",
那么就可以运行以下命令进行分析最终打包的情况了:
npm run build
npm run analyze
其他 react 的默认配置
- 直接可以使用 sass(安装 node-sass 模块后)
- 直接可以使用 css(import)
- 直接可以导入 图片、svg、字体文件等,已经配置好相应的 loader
- ES67 代码直接可以用
- class
- 箭头函数
- 私用变量
- 静态属性
- 继承
- 装饰器(XXX 不能用)
参考
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
上一篇: Flume 简介
下一篇: 彻底找到 Tomcat 启动速度慢的元凶
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论