在create-react-app中使用装饰器

字数 181阅读 848

最近做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"
    ]
  },

这样我们就可以使用装饰器语法了