为AMD,CommonJS等打包js库

时间:2013-11-30 16:33:22

标签: javascript module requirejs amd commonjs

在打包需要与AMD,CommonJS或全局一起使用的javascript库时,通常会使用如下所示的定义:

(function(name, definition) {
    if (typeof module != 'undefined') module.exports = definition();
    else if (typeof define == 'function' && typeof define.amd == 'object') define(definition);
    else this[name] = definition();
}('mod', function() {
    //Here goes the code you would normally have inside define() or add to module.exports
    return MyModule
    };
}));

这很好用,假设您的库只包含一个文件,没有外部依赖项。我不确定在发布由各种相互依赖的模块组成的库时该怎么做,可能还有外部依赖项。

即使我只想支持AMD(AMD + Bower是我的主要用例,也就是我自己使用该库的方式),我不确定是哪种方式。假设我的库发布模块foobar,其中bar取决于foo,两者都以external作为依赖项。我可以尝试做类似

的事情
// mylib/foo.js
define(['external'], function(external) {
  // whatever
});
// mylib/bar.js
define(['./foo', 'external'], function(foo, external) {
  // whatever
});

尽管如此,我无法保证我的客户会解决“外部”问题。正确。为此,客户端需要在其RequireJS定义中显式添加external的路径。如果只有一个依赖项,这仍然是可行的,但我更愿意保护客户端不必知道库使用外部。这应该在我的bower.jsonpackage.json文件中声明,但客户端不应该手动混淆传递依赖。一旦一个库有多个依赖项,每个依赖项都有其他依赖项,那么事情就会变得毛茸茸。

  

处理库中的依赖项的正确方法是什么,特别是考虑到支持多个模块标准的可能性?

1 个答案:

答案 0 :(得分:1)

我会使用r.js将模块合并到一个文件中(当然,只有内部依赖项)。

我不确定我是否正确理解了您的问题,但将几个模块合并到一个文件中可以解决您的问题。

您专注于问题,RequireJS文档已经发布了一个示例:http://requirejs.org/docs/node.html

编辑:查看jquery.js的尾部 - 他们处理了这样一种方法:https://gist.github.com/er1z/7721573