使对象传播以使用 webpack.config 和 babelrc 文件
Getting object spread to work with webpack.config and babelrc files
我正在尝试让对象传播运算符与我的 React 项目一起工作。它出现语法错误:
我已经尝试使用 babel docs 描述的 babel-plugin-transform-object-rest-spread
。
经过一番研究后,我还尝试了 GitHub issues for babel 中描述的配置:
请查看下面我的 .babelrc 文件:
{
"presets": ["es2015"],
"plugins": ["transform-object-rest-spread"],
"sourceMaps": true,
"retainLines": true
}
我的 webpack.config 文件如下:
const path = require('path');
module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js',
path: path.resolve(__dirname, 'public', 'js'),
publicPath: '/'
},
devtool: 'source-map',
module: {
rules: [
{
test: /\.jsx?$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
options: {
presets: ['react', 'es2015']
}
},
{
test: /\.css$/,
use: ['style-loader', 'css-loader']
},
{
test:/\.scss$/,
use: [{
loader: 'style-loader'
}, {
loader: 'css-loader'
}, {
loader: 'sass-loader', options: {
sourceMap: true
}
}]
},
{
test: /.(png|jpg|jpeg|gif|svg|woff|woff2|eot|ttf)(\?v=\d+\.\d+\.\d+)?$/,
loader: 'url-loader'
}
]
},
devServer: {
historyApiFallback: true,
contentBase: path.join(__dirname, 'public'),
publicPath: '/js/',
port: 3000
}
};
我使用展开运算符的代码是:
import * as types from '../types/types';
const initialState ={
mesage:''
}
export default function doodlesReducer (state = initialState, action) {
switch(action.type) {
case 'SET_MESSAGE' :
return {…state, message: action.payload.message}
default :
return state
}
}
谁能帮我找出使用对象展开运算符的正确配置?
您在 .babelrc
和 webpack.config
中都列出了您的预设,请尝试将其全部移至其中一个,即仅 .babelrc
:
{
"presets": ["es2015", "react"],
"plugins": ["transform-object-rest-spread"]
}
编辑: 另外,不要使用现已弃用的 es2015
预设,而是安装 env
预设 npm install --save-dev babel-preset-env
并在 .babelrc
将 es2015
替换为 env
.
编辑 2: 您正在使用的 …
使用了一些不受支持的字符编码,您一定是从某个地方复制粘贴了它,这弄乱了编码, 将其替换为 ...
.
我正在尝试让对象传播运算符与我的 React 项目一起工作。它出现语法错误:
我已经尝试使用 babel docs 描述的 babel-plugin-transform-object-rest-spread
。
经过一番研究后,我还尝试了 GitHub issues for babel 中描述的配置:
请查看下面我的 .babelrc 文件:
{
"presets": ["es2015"],
"plugins": ["transform-object-rest-spread"],
"sourceMaps": true,
"retainLines": true
}
我的 webpack.config 文件如下:
const path = require('path');
module.exports = {
entry: './src/index.js',
output: {
filename: 'bundle.js',
path: path.resolve(__dirname, 'public', 'js'),
publicPath: '/'
},
devtool: 'source-map',
module: {
rules: [
{
test: /\.jsx?$/,
include: path.resolve(__dirname, 'src'),
loader: 'babel-loader',
options: {
presets: ['react', 'es2015']
}
},
{
test: /\.css$/,
use: ['style-loader', 'css-loader']
},
{
test:/\.scss$/,
use: [{
loader: 'style-loader'
}, {
loader: 'css-loader'
}, {
loader: 'sass-loader', options: {
sourceMap: true
}
}]
},
{
test: /.(png|jpg|jpeg|gif|svg|woff|woff2|eot|ttf)(\?v=\d+\.\d+\.\d+)?$/,
loader: 'url-loader'
}
]
},
devServer: {
historyApiFallback: true,
contentBase: path.join(__dirname, 'public'),
publicPath: '/js/',
port: 3000
}
};
我使用展开运算符的代码是:
import * as types from '../types/types';
const initialState ={
mesage:''
}
export default function doodlesReducer (state = initialState, action) {
switch(action.type) {
case 'SET_MESSAGE' :
return {…state, message: action.payload.message}
default :
return state
}
}
谁能帮我找出使用对象展开运算符的正确配置?
您在 .babelrc
和 webpack.config
中都列出了您的预设,请尝试将其全部移至其中一个,即仅 .babelrc
:
{
"presets": ["es2015", "react"],
"plugins": ["transform-object-rest-spread"]
}
编辑: 另外,不要使用现已弃用的 es2015
预设,而是安装 env
预设 npm install --save-dev babel-preset-env
并在 .babelrc
将 es2015
替换为 env
.
编辑 2: 您正在使用的 …
使用了一些不受支持的字符编码,您一定是从某个地方复制粘贴了它,这弄乱了编码, 将其替换为 ...
.