Синтаксическая ошибка - поддержка экспериментального синтаксиса decorators-legacy в настоящее время не включена

Я пытаюсь построить JS реагировать проект с декораторами. Мой.babelrc выглядит так:

{
  "presets": [
    "@babel/preset-env",
    "@babel/preset-react",

  ],
  "plugins": [
    "@babel/plugin-transform-runtime",
    "@babel/plugin-transform-object-assign",
    [
      "@babel/plugin-proposal-decorators",
      {
        "legacy": true
      }
    ],
    ["@babel/plugin-proposal-class-properties", { "loose": true }]
  ]
}

Добавление проблем @babel/plugin-offer-decorators появляется снова.

Я использую Babel 7, Webpack 4 и реагирую 16,5

webpack.config.js:

const path = require("path");
const webpack = require("webpack");
const componentName = "reports-desktop";
const publicFolderRelativePath = "../../../../../../public/js";
const ignorePlugin = new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/);

module.exports = {
    entry: './reports-desktop.js'
    ,
    output: {
        path: path.resolve(__dirname, publicFolderRelativePath),
        filename: `${componentName}.js`
    },
    module: {
        rules: [
            {
                test: /\.js$/,
                exclude: /node_modules/,
                use: {
                    loader: "babel-loader"
                }
            }
        ]
    },
    plugins: [
        ignorePlugin
    ]
};

package.json:

{
  "name": "captain",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "watch": "webpack -w --mode development --progress --color --display-error-details",
    "build": "webpack --mode production"
  },
  "keywords": [],
  "author": "",
  "license": "ISC",
  "devDependencies": {
    "@babel/core": "^7.0.0",
    "@babel/plugin-proposal-class-properties": "^7.0.0",
    "@babel/plugin-proposal-decorators": "^7.0.0",
    "@babel/plugin-transform-object-assign": "^7.0.0",
    "@babel/plugin-transform-runtime": "^7.0.0",
    "@babel/preset-env": "^7.0.0",
    "@babel/preset-react": "^7.0.0",
    "@babel/preset-stage-1": "^7.0.0",
    "@babel/preset-stage-2": "^7.0.0",
    "babel-loader": "^8.0.2",
    "babel-plugin-transform-decorators": "^6.24.1",
    "react": "^16.5.0",
    "react-dom": "^16.5.0",
    "react-redux": "^5.0.7",
    "react-router-dom": "^4.3.1",
    "redux": "^4.0.0",
    "webpack": "^4.17.3",
    "webpack-cli": "^3.1.0"
  },
  "dependencies": {
    "axios": "^0.18.0",
    "dropzone": "^5.5.1",
    "lodash": "^4.17.10",
    "moment": "^2.22.2",
    "prop-types": "^15.6.2",
    "react-addons-update": "^15.6.2",
    "react-bootstrap": "^0.32.4",
    "react-datetime": "^2.15.0",
    "react-dnd": "^5.0.0",
    "react-dnd-html5-backend": "^5.0.1",
    "react-media": "^1.8.0",
    "react-tooltip": "^3.8.1"
  }
}

Возможно, я неправильно использую @babel/plugin-offer-decorators? Как сказано в документации, это должно исправить мою проблему, но она все еще появляется.

14 ответов

У меня была такая же проблема, но я смог заставить ее работать, запустив npm install --save-dev @babel/plugin-proposal-decorators и добавление ["@babel/plugin-proposal-decorators", { "legacy": true }] в разделе плагинов в моем .babelrc,

Раздел плагинов .babelrc, для меня сейчас выглядит так:

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

Сначала выполните команду:

npm install customize-cra react-app-rewired @babel/plugin-proposal-decorators --save

Создать новый файл config-overrides.js в корне проекта, а затем выполните следующее:

const { override, addDecoratorsLegacy } = require('customize-cra');
module.exports = override(
 addDecoratorsLegacy()
 );

Кроме того, отредактируйте ваш package.jsonфайл:

"scripts": {
 "start": "react-app-rewired start",
 "build": "react-app-rewired build",
 "test": "react-app-rewired test",
 "eject": "react-app-rewired eject"
  },

затем перезагрузите.

Взято из mobxjs. Если у вас все еще есть проблемы, обратитесь к этому. Это помогло мне.

Пример конфигурации для babel 7 в устаревшем режиме декораторов:

//.babelrc

{
    "presets": ["@babel/preset-env"],
    "plugins": [
        ["@babel/plugin-proposal-decorators", { "legacy": true }],
        ["@babel/plugin-proposal-class-properties", { "loose": true }]
    ]
}

Обратите внимание, что порядок плагинов важен, и плагины-предложения-декораторы должны быть первым плагином в вашем списке плагинов.

"devDependencies": {
    "@babel/core": "^7.1.0",
    "@babel/plugin-proposal-class-properties": "^7.1.0",
    "@babel/plugin-proposal-decorators": "^7.1.0",
    "@babel/preset-env": "^7.1.0"
}

Работа над декораторами в устаревшем режиме (этап 2) находится в стадии разработки, см. № 1732

Изменить: обновленный конфиг, чтобы показать не бета-конфигурацию для Babel 7

Я исправил это с yarn add @babel/plugin-proposal-decorators

Затем я добавил следующее babel.config.js в plugins раздел:

  [
    require('@babel/plugin-proposal-decorators').default,
    {
      legacy: true
    }
  ],

Наконец мне нужно было перезапустить мой сервер разработки веб-пакетов.


Я не проверял это, но, как говорит ответ @christopher bradshaw и согласно веб-сайту babel, если вы используете .babelrc для конфигурации, затем добавьте следующее к "plugins" раздел:

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

Если вы столкнулись с этой ошибкой при использовании ReactJS с MobX,

Don't enable decorator syntax, but leverage the MobX built-in utility decorate to apply decorators to your classes / objects.

Не рекомендуется:

import { observable, computed, action } from "mobx";

class Timer {
  @observable start = Date.now();
  @observable current = Date.now();

  @computed
  get elapsedTime() {
    return this.current - this.start + "milliseconds";
  }

  @action
  tick() {
    this.current = Date.now();
  }
}

Делать:

import { observable, computed, action, decorate } from "mobx";

class Timer {
  start = Date.now();
  current = Date.now();

  get elapsedTime() {
    return this.current - this.start + "milliseconds";
  }

  tick() {
    this.current = Date.now();
  }
}
decorate(Timer, {
  start: observable,
  current: observable,
  elapsedTime: computed,
  tick: action
});
  1. Установите декоратор в package.json
      "@babel/plugin-proposal-decorators": "^7.3.0",
"@babel/preset-flow": "^7.0.0"
  1. обновите babe.config.js этим
      module.exports = {
  "presets": [
    "module:metro-react-native-babel-preset",
    "@babel/preset-flow"
  ],
  "plugins": [
    ["@babel/plugin-proposal-decorators", { "legacy" : true }],
    ["@babel/plugin-proposal-class-properties", { "loose" : true }],
  ]
}

К сожалению, ни одно из упомянутых решений не помогло мне. Потому что им нужно, чтобы ты бежалnpm run ejectво-первых и... я не хочу этого делать. Чтобы изменить и переопределить конфигурации веб-пакета во время выполнения, существует пакет с именемreact-app-rewired и вот как его следует использовать:

Сначала установите необходимые зависимости:

npm i --save-dev customize-cra react-app-rewired

Затем добавьте новый файл с именем config-overrides.js в корневую папку проекта с этим содержимым, чтобы включить устаревший плагин декораторов babel:

const {
  override,
  addDecoratorsLegacy,
  disableEsLint
} = require("customize-cra");

module.exports = override(
  // enable legacy decorators babel plugin
  addDecoratorsLegacy(),

  // disable eslint in webpack
  disableEsLint()
);

Наконец измените package.json файл для использования react-app-rewired:

  "scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "test": "react-app-rewired test",
    "eject": "react-app-rewired eject"
  },

Теперь запустите npm start как обычно и наслаждайтесь!

С 2021 года для Create React App 4.0 требуются только следующие шаги.

  1. Убедитесь, что вы не выбросили.

  2. npm i --save-dev customize-cra react-app-rewired

  3. Добавлять config-overrides.js с участием:

      const { addDecoratorsLegacy, override } = require('customize-cra')

module.exports = override(addDecoratorsLegacy())
  1. Добавлять babel.config.js с участием:
      module.exports = {
  plugins: [['@babel/plugin-proposal-decorators', { legacy: true }]],
}
  1. Открыть package.json раздел / scripts и поиск-замена react-scripts -> react-app-rewired.
      "scripts": {
  "start": "react-app-rewired start",
  "build": "react-app-rewired build",
  "test": "react-app-rewired test",
}

После этого оба start, build, а также test команды будут работать с кодовой базой.

Чтобы использовать Mobx с Babel в 2020 году...

1

npm i babel-preset-mobx

2

module.exports = {
  presets: ['other-presets', 'mobx'],
};

Итак, просто установите mobx preset и добавьте его в файл конфигурации babel внутри presetsмассив. Например, в babel.config.js и т.п.

Package .json

"@babel/core": "^7.2.2",
"@babel/plugin-proposal-class-properties": "^7.1.0",
"@babel/plugin-proposal-decorators": "^7.1.0",
"@babel/preset-env": "^7.2.3",
"@babel/preset-react": "^7.0.0",
"@babel/register": "^7.0.0",
"babel-loader": "^8.0.5"

webpack.config.js

presets: ["@babel/preset-env", "@babel/preset-react"]

.babelrc

{
  "presets": [
    "@babel/preset-env",
    "@babel/preset-react"
  ],
  "plugins":  [
    ["@babel/plugin-proposal-decorators", { "legacy": true }],
    ["@babel/plugin-proposal-class-properties", { "loose": true }]
  ]
}

Переименован .babelrc к babel.config.jsonи это сработало!!!

Я выполнил следующие шаги, и это сработало:

1.

       npm i --save-dev customize-cra react-app-rewired @babel/plugin-proposal-
        decorators
  1. создайте в каталоге rro config-overrides.js и это:
       const { addDecoratorsLegacy, override } = require('customize-cra')
module.exports = override(addDecoratorsLegacy())
  1. редактировать скрипты package.json
       "scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "test": "react-app-rewired test",
    "eject": "react-scripts eject"   
 },

Все кредиты относятся к этой статье: https://www.tderflinger.com/en/litelement-react-app

Я пытался установить babel-plugin-transform-inline-environment-variables и это сработало.

npm install babel-plugin-transform-inline-environment-variables

С 2021 года, если вы уже «запустили Eject», отредактируйте файл с именем «babelTransform» по пути «/ config / jest / BabelTransform», например:

      ...
module.exports = babelJest.createTransformer({
  presets: [
    [
      require.resolve('babel-preset-react-app'),
      {
        runtime: hasJsxRuntime ? 'automatic' : 'classic',
      },
    ],
  ],
  "plugins": [
    [
      "@babel/plugin-proposal-decorators",
      {
        "legacy": true,
      }
    ]
  ],
  babelrc: false,
  configFile: false,
});
...

и это сработало.

Другие вопросы по тегам