关于最新create-react-app使用react-app-rewired2.x添加webpack配置
Posted 一江西流
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于最新create-react-app使用react-app-rewired2.x添加webpack配置相关的知识,希望对你有一定的参考价值。
使用过create-react-app(以下简称cra)的朋友都知道,这是react官方的一款脚手架工具,内部集成了babel,webpack,webpack-dev-server等等。
以前我们要在cra中做webpack的配置,有三种方式:
1、运行npm run eject得到原始的webpack配置文件config,然后可以看到里面有prod和dev两个环境的相关配置;但是新版本cra你run eject之后,只有一个webpack.config.js文件了。
可以在这里面进行配置。但是本文中这不是我们推荐的方式。
2、不run eject。而是改写script文件中的js。这个本人没有操作过,这个就不详谈了。
3、使用react-app-rewired,安装这个工具后,在项目根目录中新建文件config-overrides.js文件。此时我们便可以在其中进行各种webpack的骚操作了~
但是!react-app-rewired2.x以后,不再支持injectBabelPlugin的方式,需要安装customize-cra。
具体的,ant design官方文档已经给出了最新的解决方案。请前往详览。https://ant.design/docs/react/use-with-create-react-app-cn
这种方式就是我们推荐的方式。因为无需生成更多额外的文件,同时配置又趋于更简单可控的方式。
接下来我们就来具体说一下操作步骤。
首先,我们安装react-app-rewired。
$ yarn add react-app-rewired
然后修改package.json文件如下,
/* package.json */ "scripts": { - "start": "react-scripts start", + "start": "react-app-rewired start", - "build": "react-scripts build", + "build": "react-app-rewired build", - "test": "react-scripts test", + "test": "react-app-rewired test", }
接着,安装customize-cra
$ yarn add customize-cra
然后在根目录下添加config-overrides.js文件。
module.exports = function override(config, env) { // 关于webpack的相关配置 return config; };
好了,基本的操作就是这样。下面我们再来说具体到我们的项目中,需要做的一些配置。
1、react项目中我们最常用的组件库antd,我们需要配置按需加载。
使用babel-plugin-import,它是一个用于按需加载组件代码和样式的 babel 插件。
安装
$ yarn add babel-plugin-import
接着配置webpack
/* config-overrides.js */ + const { override, fixBabelImports } = require(‘customize-cra‘); - module.exports = function override(config, env) { - return config; - }; + module.exports = override( + fixBabelImports(‘import‘, { + libraryName: ‘antd‘, + libraryDirectory: ‘es‘, + style: ‘css‘, + }), + );
这样我们在组件中就可以按需引入组件库中所需要的组件了。
2、自定义主题
按照配置主题的要求,自定义主题需要用到 less 变量覆盖功能。
安装less和less-loader
$ yarn add less less-loader
配置webpack
/* config-overrides.js */ - const { override, fixBabelImports } = require(‘customize-cra‘); + const { override, fixBabelImports, addLessLoader } = require(‘customize-cra‘); module.exports = override( fixBabelImports(‘import‘, { libraryName: ‘antd‘, libraryDirectory: ‘es‘, - style: ‘css‘, + style: true, }), + addLessLoader({ + javascriptEnabled: true, + modifyVars: { ‘@primary-color‘: ‘#1DA57A‘ }, + }), );
这里利用了less-loader的modifyVars来进行主题配置。当然这里的modifyVars的值也可以是一个theme文件。
3、打包后我们会发现静态文件夹中会有很多的css和js的map文件,那么我们该怎么关闭sourcemap呢?
/* config-overrides.js */
const { override, fixBabelImports, addLessLoader } = require("customize-cra"); + process.env.GENERATE_SOURCEMAP = "false"; module.exports = override( fixBabelImports("import", { libraryName: ‘antde‘, libraryDirectory: "es", style: true, }), addLessLoader({ javascriptEnabled: true, modifyVars: { ‘@primary-color‘: ‘#1DA57A‘ }, }) );
ok,再次执行npm run build便不会产生map文件了。
还看到一种解决的方式如下,
const rewiredMap = () => config => { config.devtool = config.mode === ‘development‘ ? ‘cheap-module-source-map‘ : false; return config; }; module.exports = override( // 关闭mapSource rewiredMap() );
参考地址:https://segmentfault.com/q/1010000018123194
关于更多的customize-cra配置,大家可以自行查看文档。https://github.com/arackaf/customize-cra
以上是关于关于最新create-react-app使用react-app-rewired2.x添加webpack配置的主要内容,如果未能解决你的问题,请参考以下文章
我无法使用 npx create-react-app 安装反应?
在使用 create-react-app 创建项目时有啥方法可以使用 NPM 而不是 Yarn
使用 create-react-app 和 node 设置 jest 多项目
Bootstrap 在 create-react-app 中不起作用
运行 create-react-app 构建脚本时如何设置构建 .env 变量?
Webpack + `create-react-app` | ProvidePlugin 未将 React 作为模块加载