Babel を使用して ECMAScript 6 を ES5 にトランスパイルし、ES6 のモジュールを利用するには Browserify が必要な単純な JavaScript プロジェクトがあります。
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
機能しているにもかかわらず)。