使对象传播以使用 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
        }
}

谁能帮我找出使用对象展开运算符的正确配置?

您在 .babelrcwebpack.config 中都列出了您的预设,请尝试将其全部移至其中一个,即仅 .babelrc:

{
    "presets": ["es2015", "react"],
    "plugins": ["transform-object-rest-spread"]
}

编辑: 另外,不要使用现已弃用的 es2015 预设,而是安装 env 预设 npm install --save-dev babel-preset-env 并在 .babelrces2015 替换为 env.

编辑 2: 您正在使用的 使用了一些不受支持的字符编码,您一定是从某个地方复制粘贴了它,这弄乱了编码, 将其替换为 ....