我有一个简单的 JavaScript 项目,它使用 Babel 将 ECMAScript 6 转换为 ES5,然后需要 Browserify 来利用 ES6 的模块。
因此,我想出了这个Gruntfile.js
来编译它:
module.exports = function(grunt) {
"use strict";
grunt.loadNpmTasks('grunt-babel');
grunt.loadNpmTasks('grunt-browserify');
grunt.initConfig({
"babel": {
options: {
sourceMap: true
},
dist: {
files: {
"lib/pentagine.js": "lib/pentagine_babel.js",
"demos/helicopter_game/PlayState.js": "demos/helicopter_game/PlayState_babel.js"
}
}
},
"browserify": {
dist: {
files: {
"lib/pentagine.js": "lib/pentagine_babel.js",
"demos/helicopter_game/PlayState.js": "demos/helicopter_game/PlayState_babel.js"
}
}
}
});
grunt.registerTask("default", ["babel", "browserify"]);
};
grunt
运行良好,没有任何错误。但是,我收到以下错误:
Uncaught SyntaxError: Unexpected reserved word
开export
Uncaught SyntaxError: Unexpected reserved word
开import
基本上我在主文件中所做的如下:
export class Game {
...
}
然后像这样导入它:
import {Sprite, Game} from "lib/pentagine";
我正在根据 ECMAScript 6 编写所有代码。但是,导出/导入似乎不起作用,而是与 JavaScript 保留字冲突(尽管我有browserify.js
工作)。