【发布时间】:2016-06-16 16:43:59
【问题描述】:
我正在使用 SpineJS(它导出一个 commonjs 模块),它需要在全球范围内可用,因为我在任何地方都使用它,但似乎我必须对每个使用 Spine 的文件执行Spine = require('spine') 才能工作。
有没有办法定义一次Spine 以使其全球可用?
PS:我以 Spine 为例,但我一般想知道如何使用任何其他库来做到这一点。
【问题讨论】:
标签: browserify spine.js
我正在使用 SpineJS(它导出一个 commonjs 模块),它需要在全球范围内可用,因为我在任何地方都使用它,但似乎我必须对每个使用 Spine 的文件执行Spine = require('spine') 才能工作。
有没有办法定义一次Spine 以使其全球可用?
PS:我以 Spine 为例,但我一般想知道如何使用任何其他库来做到这一点。
【问题讨论】:
标签: browserify spine.js
在每个文件中写入Spine = require('spine') 是正确的做法。
然而,使用global 或window 对象有几种可能性(browserify 将global 对象设置为window,这是全局命名空间):
global.Spine = module.exports
global.Spine = require('spine')
window.Spine = require('spine')
【讨论】:
首先,对于您的示例,大卫是正确的。在您需要的每个模块中包含所有依赖项。它非常冗长,但没有任何编译时魔法可以缓解各种反模式和潜在的未来问题。
这并不总是实用的。 Browserify 接受一个名为insertGlobalVars 的选项。在构建时,会扫描每个流文件以查找与提供的键名匹配的标识符,并将模块包装在 IIFE 中,其中包含解析模块中未分配的每个标识符的参数。这一切都发生在依赖关系树最终确定之前,这允许您使用 require 来解决依赖关系。
在 Browserify 中使用 insertGlobalVars 选项。
browserify({
insertGlobalVars: {
spine: function(file, dir) {
return 'require("spine")';
}
}
});
对于每个扫描的文件,如果存在未分配的标识符spine,则解析为require("spine")。
【讨论】: