现在,RequireJS2.X使用新
shim配置可以更好地有机解决非AMD模块,例如Backbone&Underscore 。
该
shim配置易于使用:(1)声明依赖项(
deps)(如果有)(可能来自
paths配置,也可能是有效路径本身)。(2)(可选)从要填充的文件中指定全局变量名称,该名称应导出到需要它的模块函数中。(如果不指定导出,则只需使用全局变量,因为任何内容都不会传递到您的require/ define函数中。)
这是
shim加载Backbone 的简单示例用法。即使没有任何依赖性,它也会为下划线添加导出。
require.config({ shim: { underscore: { exports: '_' }, backbone: { deps: ["underscore", "jquery"], exports: "Backbone" } }});//the "main" function to bootstrap your prerequire(['jquery', 'underscore', 'backbone'], function ($, _, Backbone) { // or, you could use these deps in a separate module using define});注意: 此简化的代码假定jquery,bone和underscore位于与此“ main”代码相同的目录下的名为“ jquery.js”,“
backbone.js”和“ underscore.js”的文件中(这将成为require的baseURL )。如果不是这种情况,则需要使用path
config。
我个人认为,使用内置
shim功能,不使用分叉版本的Backbone&Underscore的优势要胜过使用另一个流行答案中推荐的AMD叉的优势,但是无论哪种方式都能奏效。



