我希望有人可以提供帮助。
我正在使用grunt-babel将我的ES6模块代码转换为ES5 AMD模块代码。这是我的ES6代码:
multiply.js
export default function (x,y) {
return x * y;
};
square.js
import multiply from 'multiply';
export default function (x) {
return multiply(x,x);
};
app.js
import square from 'square';
var myValue = square(2);
console.log(myValue);
正如您所看到的,我正在做的就是创建一个模块'multiply',将其导入另一个模块'square',然后最后在我的主js文件中使用'square'。然后将上述3个文件转换为以下内容:
multiply.js
define("multiply", ["exports", "module"], function (exports, module) {
module.exports = function (x, y) {
return x * y;
};
});
square.js
define("square", ["exports", "module", "multiply"], function (exports, module, _resourcesJsEs6moduleExampleMultiply) {
var _interopRequire = function (obj) { return obj && obj.__esModule ? obj["default"] : obj; };
var multiply = _interopRequire(_resourcesJsEs6moduleExampleMultiply);
module.exports = function (x) {
return multiply(x, x);
};
});
app.js
define("app", ["exports", "square"], function (exports, _resourcesJsEs6moduleExampleSquare) {
var _interopRequire = function (obj) { return obj && obj.__esModule ? obj["default"] : obj; };
var square = _interopRequire(_resourcesJsEs6moduleExampleSquare);
var myValue = square(2);
console.log(myValue);
});
我遇到的问题是我希望'app.js'文件转换为更像这样的东西:
requirejs(['square'],
function (square) {
var myValue = square(2);
console.log(myValue);
}
);
在我的gruntfile.js中,我的配置非常简单:
options: {
moduleIds: true,
modules: 'amd',
blacklist: ['strict']
}
我做错了吗?
答案 0 :(得分:1)
在我目前的筹码中,我被迫使用杏仁而不是RequireJS。因此,Almond希望有一个文件来初始化模块,因此我期待Babel为我生成一个。但事实证明,Babel生成的代码在RequireJS中可以正常工作,但是为了与Almond一起工作,我需要创建一个单独的es5 js文件,只是为了初始化Babel生成的文件。
这样的事情:
requirejs(['app'],
function (app) {
app();
}
);