我想将两个需要amd模块组合成一个combined.js javascript文件,使用Webpack。Webpack - 将两个匿名模块组合成一个combined.js文件
module1.js
//module1.js - objectTest1
(function (root, factory) {
'use strict';
//Universal Module Definition
if (typeof define === 'function' && define.amd) {
// AMD
define(factory);
} else if (typeof exports === 'object') {
// Node, CommonJS-like
module.exports = factory();
} else {
// Browser globals (root is window)
root.returnExports = factory();
}
}(this, function() {
'use strict';
return function objectTest1() {
var test = '1';
return test;
};
}));
module2.js
//module2.js - objectTest2
(function (root, factory) {
'use strict';
//Universal Module Definition
if (typeof define === 'function' && define.amd) {
// AMD
define(factory);
} else if (typeof exports === 'object') {
// Node, CommonJS-like
module.exports = factory();
} else {
// Browser globals (root is window)
root.returnExports = factory();
}
}(this, function() {
'use strict';
return function objectTest2() {
var test = '2';
return test;
};
}));
推荐好的做法
在requireJS维基和其他来源,是一个很好的做法,他们明确建议不要设置名称每个模块,而是把它匿名没有ID: https://github.com/requirejs/requirejs/wiki/Updating-existing-libraries#anon
“通常你不应该注册一个名为模块,而是注册为匿名模块...”
的WebPack - 结合在一个JS文件的模块
[webpack.config.js]
module.exports= {
entry: [
"./modules/module1.js",
"./modules/module2.js"
],
output: {
filename:"combined.js",
libraryTarget: "umd",
umdNamedDefine: true
}
};
[Ejecute的WebPack结合]
webpack.js
webpack 2.5.1
Time: 64ms
Asset Size Chunks Chunk Names
combined.js 5.11 kB 0 [emitted] main
[0] ./modules/module1.js 551 bytes {0} [built]
[1] ./modules/module2.js 551 bytes {0} [built]
[2] multi ./modules/module1.js ./modules/module2.js 40 bytes {0} [built]
的WebPack - 输出 - combined.js
试图加载combined.js文件和模块与RequireJS
[index.html]
require(["combined", "combined/modules/module1", "combined/modules/module2"],
function (combined, objectTest1, objectTest2) {
//combined = objectTest1
//
//objectTest1 = objectTest1 - OK!
//
//objectTest2 = objectTest1 - **WRONG**
//
}
);
问题
当装载combined.js文件,我总是让合并后的文件中定义的第一个匿名模块。我不知道如何让第二个模块,它从来没有在requireJS变量设置:window.requirejs.s.contexts ._定义
附加信息
如果我建立与模块在每个模块的define('name',..)中有一个'id name',它可以完美地工作,我可以完美地加载它们,但是正如上面所解释的,它不是一个很好的命名模块的方法。
问题
- 我怎么能在一个组合结合这些匿名模块。js文件,用requireJS加载该文件,然后获取每个模块?
- 代码中可能有问题吗?
- 我查看了requireJS变量:window.requirejs.s.contexts ._。定义了查找所有模块,但第二个模块从未添加到那里。所以我想这可能是我使用的UMD模式或Webpack不支持的功能的问题。
我越来越绝望地试图解决它,并已通过许多资源查找,但无法找到明确的答案。 非常感谢