4

我有一个简单的 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 wordexport Uncaught SyntaxError: Unexpected reserved wordimport

基本上我在主文件中所做的如下:

export class Game {
    ...
}

然后像这样导入它:

import {Sprite, Game} from "lib/pentagine";

我正在根据 ECMAScript 6 编写所有代码。但是,导出/导入似乎不起作用,而是与 JavaScript 保留字冲突(尽管我有browserify.js工作)。

4

1 回答 1

5

你不应该在任务browserify之后创建文件吗?babel请注意,属性名称是目标文件,后面的值:是源文件。(我假设您的 ES6 文件被调用filename.js而不是filename_babel.js

files: {
   "destination_file": "src_file"
}

这导致:

grunt.initConfig({
    "babel": {
      options: {
        sourceMap: true
      },
      dist: {
        files: {
          "lib/pentagine_babel.js": "lib/pentagine.js",
          "demos/helicopter_game/PlayState_babel.js": "demos/helicopter_game/PlayState.js"
        }
      }
    },

    "browserify": {
      dist: {
        files: {
          "lib/pentagine_browserified.js": "lib/pentagine_babel.js",
          "demos/helicopter_game/PlayState_browserified.js": "demos/helicopter_game/PlayState_babel.js"
        }
      }
    }
  });

或者只是lib/pentagine_babel.js": "lib/pentagine_babel.js"browserify同一个文件。

于 2015-03-27T06:43:52.150 回答