最近做react项目的时候,使用的是create-react-app脚手架搭建的项目,用的ant-design框架,在使用UI框架的Form组件的时候,发现 Form.create
方法是一个典型的装饰器,于是就改成装饰器的写法,但是在项目编译的过程中却并不如意,项目抛出了如下错误
The 'decorators' plugin requires a 'decoratorsBeforeExport' option
解决办法:
1、先安装包 react-app-rewired
yarn add react-app-rewired
2、安装装饰器语法所需的babel插件, 也可以顺带升级babel-core
yarn add @babel/plugin-proposal-decorators metro-react-native-babel-preset -D
3、在项目根目录下创建.babelrc, config-overrides.js文件
// .babelrc
{
"presets": ["module:metro-react-native-babel-preset"],
"plugins": [
[
"@babel/plugin-proposal-decorators",
{
"legacy": true
}
]
]
}
// config-overrides
const { getBabelLoader } = require('react-app-rewired');
const path = require('path');
module.exports = function override(config, env) {
const babelLoader = getBabelLoader(config.module.rules);
const pwd = path.resolve();
babelLoader.include = [path.normalize(`${pwd}/src`)];
// use babelrc
babelLoader.options.babelrc = true;
return config;
};
4、删除package.json的babel配置
// 删除下面几行
"babel": {
"presets": [
"react-app"
]
},
这样我们就可以使用装饰器语法了