你可以使用我所说的 require js 模块模式。如果你知道一组类经常一起使用,你可以这样做。
首先在一个单独的文件中定义每个类,然后定义一个模块将它们组合在一起
Module.js
define([
'./models/FirstModel',
'./models/SecondModel',
'./views/FirstView',
'./views/SecondView',
'txt!./templates/template.tpl'
], function(FirstModel, SecondModel, FirstView, SecondView, template) {
return {
FirstModel: FirstModel,
SecondModel: SecondModel,
FirstView: FirstView,
SecondView: SecondView,
template: template
}
});
然后当你想使用这个模块中的类时,你只需这样做
define(['./Module'], function(Module) {
var AView = Module.FirstView.extend({
model: Module.FirstModel,
render: function() {
this.html(_.template(Module.template)(this.model.attributes));
if (something) {
this.$el.append(new Module.SecondView().render().el);
}
}
})
return AView;
});
我不认为使用 requirejs 定义的模块我们应该返回一个实例——我们应该总是返回一个构造函数或一个对象。
您应该完全接受定义和要求 - 随着时间的推移,您会开始喜欢它 - 而不必考虑手动添加/跟踪依赖项等,或者(所以 2005 年!)将大部分东西合二为一文件:)