我正在尝试创建一个单例对象作为主干上视图的模型,并且我想在更改和更新此单例对象时重新呈现视图。我不确定以下代码是否是正确的方法
模型
define(function(require) {
var Singleton = require("modules/Singleton");
var Singleton = null;
var SingletonHolder = {
init: function() {
Singleton = new Singleton();
return Singleton.fetch();
},
current: function() {
return Singleton;
},
refresh: function() {
return Singleton.fetch();
}
};
return SingletonHolder;
});
控制器
var currentObj = SingletonHolder.current();
var tempView = new TempView({
model: currentObj
});
查看
var TempView = Backbone.View.extend({
initialize: function() {
this.listenTo(this.model, "change", this.render);
}
render: function() {
...
}
});
由于某些原因,它不起作用。我错过了什么吗?我还尝试调用Singleton.refresh,它进入服务器端并从数据库中获取最新数据,但它没有检测到更改并重新呈现视图。
答案 0 :(得分:1)
如果您已使用requirejs,则不必定义Singleton。
的Singleton:
define(['models/foo'], function(FooModel){
return new FooModel;
})
控制器:
define(['foosingleton', 'tempview'], function(fooSingleton, TempView){
var tempView = new TempView({
model: fooSingleton
});
});
以下是一个类似的问题:Is it a bad practice to use the requireJS module as a singleton?