意外的令牌{当尝试用JS ES6吞咽时

时间:2016-08-30 11:23:19

标签: javascript node.js gulp ecmascript-6 gulp-babel

我是否使用了某个软件包的错误版本,或者您是否可以向我发送详细教程或codepen的链接,其中此语法构造不会给我一个错误?

我收到此错误:

$ gulp
D:\GIT\project02\gulpfile.js:20
const { COMPATIBILITY, PORT, UNCSS_OPTIONS, PATHS } = loadConfig();
      ^

SyntaxError: Unexpected token {
    at exports.runInThisContext (vm.js:53:16)
    at Module._compile (module.js:413:25)
    at Object.Module._extensions..js (module.js:452:10)
    at Module.load (module.js:355:32)
    at Function.Module._load (module.js:310:12)
    at Module.require (module.js:365:17)
    at require (module.js:384:17)
    at execute (C:\Documents and Settings\Administrator\Application Data\npm\node_modules\gulp-cli\lib\versioned\^4.0.0-alpha.2\index.js:36:18)
    at Liftoff.handleArguments (C:\Documents and Settings\Administrator\Application Data\npm\node_modules\gulp-cli\index.js:172:63)
    at Liftoff.<anonymous> (C:\Documents and Settings\Administrator\Application Data\npm\node_modules\gulp-cli\node_modules\liftoff\index.js:198:16)

我已经阅读了this question,但'use strict';在我的gulp文件中,并且更改const以让我无效。

我全局安装的软件包:

$ npm -g ls --depth=0
C:\Documents and Settings\Administrator\Application Data\npm
├── babel-cli@6.14.0
├── babel-core@6.14.0
├── babel-preset-es2015@6.14.0
├── bower@1.7.9
├── gulp-babel@6.1.2
└── gulp-cli@1.2.2 (git://github.com/gulpjs/gulp-cli.git#9b053ed9b7a63a10777c33b86b04ed38d7f5b840)

我的节点是v4.0.0,我正在项目中使用gulp:

$ gulp -v
[14:15:06] CLI version 1.2.2
[14:15:06] Local version 4.0.0-alpha.2

2 个答案:

答案 0 :(得分:3)

正如Konstantin所说,并非所有ES6功能都在Gulpfile中可用,因为节点必须处理这些文件。但是使用babel-require挂钩可以轻松实现此目的。

创建一个这样的Gulp文件:

'use strict';

// Compile task to ES5 on the fly!
require('babel-register');

// Require all tasks!
require('require-dir')('./tasks', { recurse: true });

并将您的任务放在tasks目录中。然后创建一个.babelrc文件来加载预设,例如

{
    "presets": ["node5"]
}

当您使用节点 v5.x 时。现在您可以使用ES6功能了! :)

答案 1 :(得分:1)

Destructing是ES6功能,从Node v6开始正式支持。所以你应该替换:

const { COMPATIBILITY, PORT, UNCSS_OPTIONS, PATHS } = loadConfig();

使用:

const config =  loadConfig(),
      COMPATIBILITY = config.COMPATIBILITY,
      PORT = config.PORT,
      UNCSS_OPTIONS = config.UNCSS_OPTIONS,
      PATHS = config.PATHS

或更新您的节点版本。