ECMAScript 6 (BabelJS でトランスパイルし、Browserify でブラウザ化) を使用してフロントエンド コードを作成しているため、1 つのファイルにクラスを格納し、それをエクスポートして、別のファイルにインポートできます。
私がこれをやっている方法は次のとおりです。
export class Game {
constructor(settings) {
...
}
}
そして、私が行うクラスをインポートするファイルで:
import {Game} from "../../lib/pentagine_browserified.js";
var myGame = new Game(settings);
次に、でコンパイルしますgrunt
。これは私のGruntfile
です:
module.exports = function(grunt) {
"use strict";
grunt.loadNpmTasks('grunt-babel');
grunt.loadNpmTasks('grunt-browserify');
grunt.initConfig({
"babel": {
options: {
sourceMap: false
},
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"
}
}
}
});
grunt.registerTask("default", ["babel", "browserify"]);
};
ただし、new Game(
呼び出し時に次のエラーが表示されます。
Uncaught TypeError: undefined is not a function
そのため、Babel と Browserify によって生成されたコードを分析したところ、次の行が見つかりましたPlayState_browserified.js
。
var Game = require("../../lib/pentagine_browserified.js").Game;
出力を印刷することにしましたrequire
:
console.log(require("../../lib/pentagine_browserified.js"));
そして、それは空のオブジェクトに他なりません。pentagine_browserified.js
ファイルをチェックアウトすることにしました:
var Game = exports.Game = (function () {
クラスを正しくエクスポートしているように見えますが、他の理由で他のファイルでは必要ありません。
"../../lib/pentagine_browserified.js"
また、文字列を変更するとNot Found
エラーが発生するため、ファイルが適切に必要とされていると確信しているため、正しいファイルに移動していると確信しています。