React-MobX Error: The 'decorators' plugin requires a 'decoratorsBeforeExport' option, whose value must be a boolean

前端 未结 5 680
無奈伤痛
無奈伤痛 2021-02-12 11:52

I get the following error: If you are migrating from Babylon/Babel 6 or want to use the old decorators proposal, you should use the \'decorators-legacy\' plugin instead of \'dec

5条回答
  •  無奈伤痛
    2021-02-12 12:50

    The error message is a little bit confusing however with some little bit deep searching, you can resolve it using the following approach.

    I make no assumptions, except that you are using webpack in this guide.

    You need to add babel proposal decorators to your dev dependencies (You only need it during dev time) (which you have added already).

    if using yarn

    yarn add --dev @babel/plugin-proposal-decorators 
    

    otheriwse for npm

    npm install --save-dev @babel/plugin-proposal-decorators 
    

    then in your package.json file, locate babel config section or add one if not there. The config name is strictly "babel".

      "babel": {
        "presets": [
          "react-app"
        ],
        "plugins": [
          [
            "@babel/plugin-proposal-decorators",
            {
              "legacy": true
            }
          ]
        ]
      }
    

    Pay extra attention to the indentation if typing it by hand. notice the object "@babel/plugin-proposal-decorators" is deeply nested inside two arrays, so it has to be as such to work.

    and just for sanity check, your devDependencies would at a minimum be as

      "devDependencies": {
        "@babel/plugin-proposal-decorators": "^7.1.2"
      }
    

    Now you can build your application with either yarn or npm and live happily ever after.

提交回复
热议问题