react 不eject扩展webpack
栏目: JavaScript · 发布时间: 7年前
内容简介:使用
使用 create-react-app
生成项目,不会有 webpack
的配置项,要导出 webpack
,必须使用 react-script eject
,但这是一个单向操作, eject
后,就无法恢复了。如果只是修改一些简单的配置, eject
是没有必要的。
1、使用 react-app-rewired
包替换 react-script
react-app-rewired@^2.0.0+
版本需要搭配 customize-cra
使用
# https://www.npmjs.com/package/react-app-rewired # https://www.npmjs.com/package/customize-cra $ npm i react-app-rewired -D $ npm i customize-cra -D 复制代码
2、在项目根目录创建 config-overrides.js
3、使用 react-app-rewired
配置 alias
# ./config-overrides.js
const { override, addWebpackAlias } = require('customize-cra')
const path = require('path')
const resolve = dir => path.join(__dirname, '.', dir)
module.exports = override(
addWebpackAlias({
['@']: resolve('src')
})
)
复制代码
4、添加 react-hot-reloader
# https://www.npmjs.com/package/react-hot-loader # https://github.com/cdharris/react-app-rewire-hot-loader $ npm i react-hot-loader -D $ npm i react-app-rewire-hot-loader -D 复制代码
5、修改 config-overrides.js
# https://github.com/arackaf/customize-cra/issues/54
# ./config-overrides.js
const { override, addWebpackAlias } = require('customize-cra')
const path = require('path')
const resolve = dir => path.join(__dirname, '.', dir)
module.exports = override(
addWebpackAlias({
['@']: resolve('src')
}),
(config, env) => {
config = rewireReactHotLoader(config, env)
return config
}
)
复制代码
6、在根组件处开启 react-hot-reloader
# ./App.jsx
import { hot } from 'react-hot-loader/root'
...
...
...
export default process.env.NODE_ENV === 'development' ? hot(App) : App;
复制代码
7、引入 antd
按需加载
+ const { override, fixBabelImports, addWebpackAlias } = require('customize-cra')
const rewireReactHotLoader = require('react-app-rewire-hot-loader')
const path = require('path')
const resolve = dir => path.join(__dirname, '.', dir)
module.exports = override(
+ fixBabelImports('import', {
+ libraryName: 'antd',
+ libraryDirectory: 'es',
+ style: 'css'
+ }),
addWebpackAlias({
['@']: resolve('src')
}),
(config, env) => {
config = rewireReactHotLoader(config, env)
return config
}
)
复制代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
CSS3实用指南
吉伦瓦特 / 屈超、周志超 / 人民邮电出版社 / 2012-3 / 49.00元
CSS3为Web的视觉样式语言注入了强大的新功能,让设计人员更加轻松自如地设计优美而引人入胜的内容。借助CSS3,不使用图片就可以创建半透明背 景、渐变、阴影等夺人眼球的视觉效果;还可以使用漂亮、独特、非Web安全的字体显示文本;不用Flash就可以创建动画;不用JavaScript就可 以定制适应用户的设备和屏幕尺寸的设计。 本书通过一系列实用且新颖的范例,向读者展示如何实现以上功能和更多......一起来看看 《CSS3实用指南》 这本书的介绍吧!