gpt4 book ai didi

javascript - 使用 babel 装饰器时意外的标记 @

转载 作者:行者123 更新时间:2023-11-30 08:27:20 26 4
gpt4 key购买 nike

我目前正在构建一个 React 项目,并已开始使用 connect 合并 redux。我正在使用装饰器来引用它,即

const mapStateToProps = (state) => {
return {
active: state.sortOrder
}
};

@connect(mapStateToProps)
export default class SortFilter extends Component {
//component code here
}

SyntaxError: /Sort.js: Unexpected token (10:0) @connect(mapStateToProps)

这是我的 webpack 配置,其中包含 babel-transform-decorators 和 stage-0 预设(因为这似乎是其他人的解决方案)。

const PATH = require('path');

const webpack = require("webpack");

const ROOT = '../../../';

const APP_FOLDER = PATH.resolve(__dirname, ROOT, 'app/');
const APP_ENTRY_FILE = PATH.resolve(__dirname, ROOT, APP_FOLDER, 'client.js');

const BUILD_FOLDER = PATH.resolve(__dirname, ROOT, 'app/public/js/');
const PUBLIC_PATH = '/js/';

const BUILD_FILE = 'app.js';

const ESLINT_CONFIG_FILE = PATH.resolve(__dirname, ROOT, 'tools/build/config/eslint-config.json');

var webpackConfig = {
entry: {
app: APP_ENTRY_FILE
},
output: {
path: BUILD_FOLDER,
publicPath: PUBLIC_PATH,
filename: BUILD_FILE
},
devtool: 'inline-source-map',
debug: true,
bail: true,
eslint: {
configFile: ESLINT_CONFIG_FILE
},
module: {
preLoaders: [
{
test: /\.js$/,
include: [
APP_FOLDER
],
loader: 'eslint-loader'
}
],
loaders: [
{
test: /\.js$/,
include: [
APP_FOLDER
],
loader: 'babel',
query: {
compact: false,
cacheDirectory: true,
presets: ['es2015', 'react', 'stage-0'],
plugins: ['transform-decorators-legacy']
}
}
]
},
externals: {
'axios': 'axios',
'react': 'React',
'react-router': 'ReactRouter',
'history': 'History',
'react-dom': 'ReactDOM'
},
plugins: [
new webpack.NoErrorsPlugin()
]
};

module.exports = webpackConfig;

如果您能帮助解决这个问题,我们将不胜感激。

最佳答案

你需要安装babel-plugin-transform-decorators:

npm install babel-plugin-transform-decorators-legacy --save-dev

然后在.babelrc中添加:

"plugins": ["transform-decorators-legacy"]

关于javascript - 使用 babel 装饰器时意外的标记 @,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43492086/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com