Browserify、Babel 6、Gulp - 点差运算符上的意外令牌

IT技术 javascript gulp ecmascript-6 browserify babeljs
2021-01-31 15:48:35

我试图让我的 Browserify/Babelify/Gulp 在我的项目中工作,但它不会采用传播运算符。

我从我的 gulpfile 中得到这个错误:

[SyntaxError: /Users/mboutin2/Desktop/Todo-tutorial/src/reducers/grocery-list-reducers.js: Unexpected token (16:8) while parsing file: /Users/mboutin2/Desktop/Todo-tutorial/src/reducers/grocery-list-reducers.js]

这是我的 gulpfile.js

var gulp = require('gulp');
var source = require('vinyl-source-stream');
var browserify = require('browserify');
var sourcemaps = require('gulp-sourcemaps');
var uglify = require('gulp-uglify');
var buffer = require('vinyl-buffer');
var babelify = require('babelify');

gulp.task('build', function () {
  return browserify({entries: './src/client/app.js', extensions: ['.js'], debug: true})
    .transform(babelify, {presets: ['es2015', 'react']})
    .bundle()
    .on('error', function (err) {
      console.error(err);
      this.emit('end');
    })
    .pipe(source('app.min.js'))
    .pipe(buffer())
    .pipe(sourcemaps.init({loadMaps: true}))
    .pipe(uglify())
    .pipe(sourcemaps.write('./'))
    .pipe(gulp.dest('./public/js'));
});

gulp.task('default', ['build']);

我试图创建一个 .babelrc 文件,但它做同样的事情。当我删除传播运算符时,我的脚本可以工作。

这是发生意外令牌的文件(很简单)。

import utils from '../utils/consts';

const initialState = {
  itemList: [
    {name: 'Apple', type: 'Fruit'},
    {name: 'Beef', type: 'Meat'}
  ]
};

export function groceryList(state = initialState, action = {}) {

  switch(action.type) {

    case utils.ACTIONS.ITEM_SUBMIT:
      return {
        ...state,
        itemList: [
          ...state.itemList,
          {name: action.name, type: action.itemType}
        ]
      };

    default:
      return state;

  }
}

我不知道什么不起作用,我在 Github 和 Babel 网站上的设置页面上阅读了一些问题,但我无法使其正常工作。

谁能告诉我如何正确处理这个问题?谢谢

3个回答

这句法是未来的一个实验提出的语法,它不是一部分es2015或者react所以你需要启用它。

npm install --save-dev babel-plugin-transform-object-rest-spread

并添加

"plugins": ["transform-object-rest-spread"]

.babelrc在保留现有presets

或者:

npm install --save-dev babel-preset-stage-3

stage-3在您的预设中使用以启用所有第 3 阶段实验功能。

目前是第3阶段!:D
2021-03-19 15:48:35
通过 CLI,您需要一个 .babelrc 文件,并且预设位于 babeljs 站点的插件页面中
2021-03-20 15:48:35
npm install --save-dev babel-preset-stage-3 presets: ["stage-3"]为我做了。
2021-04-04 15:48:35
@MikeBoutin loganfsmyth 你能指定在哪里将它指定为预设吗?我有同样的问题,虽然我通过 cli 使用 babelify。谢谢
2021-04-09 15:48:35

我遇到了同样的问题,安装了 stage-2 插件并修改了我的 package.json 文件,如下所示

"babel": {
    "presets": [
      "es2015",
      "react",
      "stage-2"
    ]
  }

...顺便提一下,一些文本编辑器(在我的例子中是 Mac Notes)会收缩成一个 elepsis 实体,这将无法通过验证,所以也要注意这一点......

那不是我的文本编辑器。这只是我偶尔转储代码块的地方。:D
2021-03-18 15:48:35
值得指出的是,各种产品,包括微软产品和诸如 slack 之类的东西,通常会插入自己的特殊格式字符(通常是隐藏的)和/或转换某些字符以显示外观。这真的很难发现,并且会给你带来问题......
2021-03-27 15:48:35