create-react-app 设置文件路径别名
使用 eject 扩展 webpack
前言
本文基于 (“react”: “^16.13.1”) 版本
react官方脚手架默认是将webpack配置隐藏起来了,在进行配置之前需要将webpack给暴露出来。
1.输入命令 npm run eject
会出现一个命令提示:这是一个单向操作,确认操作后不可逆转/返回?
输入 y 回车
成功之后 在项目根目录出现 config 文件夹
2.打开 config 文件夹下的 webpack.config.js 文件
3.进行搜索 alias ,大概在 291 行的位置
4.参照如下格式,设置路径别名
alias: {
// Support React Native Web
// https://www.smashingmagazine.com/2016/08/a-glimpse-into-the-future-with-react-native-for-web/
'react-native': 'react-native-web',
// Allows for better profiling with ReactDevTools
...(isEnvProductionProfile && {
'react-dom$': 'react-dom/profiling',
'scheduler/tracing': 'scheduler/tracing-profiling',
}),
...(modules.webpackAliases || {}),
// 文件路径别名
'@': path.resolve(__dirname, '../src'),
'@view': path.resolve(__dirname, '../src/view'),
},
5.在项目中使用
打开 index.js ,将 import ./index.css 替换成 import '@/index.css’
注: @ 在上面已经被设置 src 文件路径
6.启动项目, 无报错,并且样式生效
react 不eject扩展webpack
使用 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
然后在 package.json 文件中将 script 的配置项替换成如下
"scripts": {
"start": "react-app-rewired start",
"build": "react-app-rewired build",
"test": "react-app-rewired test",
"eject": "react-scripts eject"
}
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
}
)
转自: