美文网首页
create-react-app常用的再配置

create-react-app常用的再配置

作者: 小小的开发人员 | 来源:发表于2019-06-21 15:16 被阅读0次

    使用Facebook官方推出的create-react-app脚手架,我们基本可以零配置搭建基于webpack的React开发环境。但是,如果需要个性化定制,则还需要基于create-react-app进行再配置。

    环境变量

    【设置】
      在根目录下新建.env文件,可以用于本地环境变量覆盖,如在该文件中进行如下设置。

    PORT=2000
    

    则开发服务器会在2000端口开启服务。

    【默认】
      默认支持的环境变量有: NODE_ENV 和 PUBLIC_URL
      NODE_ENV: 该变量是自动赋值的,你不可以更改它的值,对于npm start, 它的值是develepment, npm test它的值是test, 对于npm run build, 它的值是production
      PUBLIC_URL: 这个变量可以用于引用模块系统之外的资源路径前缀

    【区分环境】
      一般地,在开发端,会使用redux-logger在控制台显示触发action时的日志,但在生产端,则完全不需要。可以使用NODE_ENV环境变量来区分环境

    let store = null
    if (process.env.NODE_ENV === 'development') {
      store = createStore(rootReducer, applyMiddleware(thunk, logger))
    } else {
      store = createStore(rootReducer, applyMiddleware(thunk))
    }
    

    【外部资源】
      如果要设置静态资源CDN,则需要在.env文件中设置PUBLIC_URL

    PUBLIC_URL = 'cdn url'
    

    在HTML中使用

    <link rel="shortcut icon" href="%PUBLIC_URL%/favicon.ico">
    

    在Javascript中使用

    return <img src={process.env.PUBLIC_URL + '/img/logo.png'} />
    

    【自定义】
      可以自定义环境变量,不过需要遵照一个约定,所有自定义环境变量均以REACT_APP_开头。
      这些环境变量会定义在process.env中。例如,环境变量REACT_APP_SECRET_CODE会在JS中暴露为process.env.REACT_APP_SECRECT_CODE。

    配置代理

    在package.json中配置,与其他项目同级

    "scripts": {
        "start": "react-scripts start",
        "build": "react-scripts build",
        "test": "react-scripts test --env=jsdom",
        "eject": "react-scripts eject"
      },
      "proxy": {
        "/api": {
          "target": "https://m.weibo.cn",
          "changeOrigin": true,
          "pathRewrite":{"^/api":""}
        }
      }
    

    配置别名

    【rewire】
      使用react-app-rewired来进行react的再配置,首先使用npm安装

    npm install react-app-rewired --save-dev
    

    然后,更改package.json中的scripts部分

    "scripts": {
        "start": "react-app-rewired start",
        "build": "react-app-rewired build",
        "test": "react-app-rewired test --env=jsdom",
        "eject": "react-app eject"
      },
    

    然后,在根目录新建config-overrides.js文件,配置如下

    const path = require('path');
    function resolve(dir) {
        return path.join(__dirname, '.', dir)
    }
    module.exports = function override(config, env) {
        config.resolve.alias = {
            '@': resolve('src')
        }
        return config;
    }
    

    重启开发服务器后,就可以使用@来表示'src'的绝对路径了

    【eject】
      或者,npm run eject之后 ,直接更改config目录下的dev.js和prod.js文件中的alias设置。

        alias: {
          '@': path.join(__dirname, '..', 'src'),
          ... 
        },
    

    配置eslint

    安装插件

    npm install react-app-rewired react-app-rewire-eslint --save
    

    在根目录下新建.eslint.js文件,文件中一定要添加如下配置

    module.exports = {
      "parser":"babel-eslint",
        ...
    

    否则,会报下面的错误

    Parsing error: Unexpected token =
    

    相关文章

      网友评论

          本文标题:create-react-app常用的再配置

          本文链接:https://www.haomeiwen.com/subject/efwyqctx.html