单例对象上的主干事件监听器

时间:2013-04-26 15:19:15

标签: javascript backbone.js requirejs backbone-views backbone-events

我正在尝试创建一个单例对象作为主干上视图的模型,并且我想在更改和更新此单例对象时重新呈现视图。我不确定以下代码是否是正确的方法

模型

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,它进入服务器端并从数据库中获取最新数据,但它没有检测到更改并重新呈现视图。

1 个答案:

答案 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?