Синтаксическая ошибка - поддержка экспериментального синтаксиса 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
});
- Установите декоратор в package.json
"@babel/plugin-proposal-decorators": "^7.3.0",
"@babel/preset-flow": "^7.0.0"
- обновите 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 требуются только следующие шаги.
Убедитесь, что вы не выбросили.
npm i --save-dev customize-cra react-app-rewired
Добавлять
config-overrides.js
с участием:
const { addDecoratorsLegacy, override } = require('customize-cra')
module.exports = override(addDecoratorsLegacy())
- Добавлять
babel.config.js
с участием:
module.exports = {
plugins: [['@babel/plugin-proposal-decorators', { legacy: true }]],
}
- Открыть
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 }]
]
}
Я выполнил следующие шаги, и это сработало:
1.
npm i --save-dev customize-cra react-app-rewired @babel/plugin-proposal- decorators
- создайте в каталоге rro config-overrides.js и это:
const { addDecoratorsLegacy, override } = 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-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,
});
...
и это сработало.