如何在backbone.js模型中添加私有函数?

时间:2011-12-12 10:15:25

标签: javascript backbone.js

有没有办法在骨干网中创建一个私有函数,以便它只暴露给模型本身并且还可以访问this

如何将updateTime设为私有?

   var Timeline = Backbone.Model.extend({
        url: 'servertime/',

        start: function(){
            this.fetch({
                success: function(timeline, response){
                    timeline.updateTime();
                    setInterval(function() {
                        timeline.updateTime();
                    }, 60 * 1000);
                }
            });
        },

        updateTime: function(){  //How can I make this private?
            this.time = ...
        }
    });

2 个答案:

答案 0 :(得分:14)

你可以通过在一个自我调用的匿名函数中包装它来实现这一点,这样你就可以确定updateTime是私有的:

(function() {
  var updateTime = function(){  // this stays private to this anonymous function
    this.time = ...
  },
  Timeline = Backbone.Model.extend({
    url: 'servertime/',

    start: function(){
      this.fetch({
        success: function(timeline, response){
          updateTime.call(timeline);
          setInterval(function() {
            updateTime.call(timeline);
          }, 60 * 1000);
        }
      });
    }
  });

})();

答案 1 :(得分:7)

您可以将updateTime设为私有功能,而不是私有方法。 我还建议在前面添加一个下划线,以明确它是一个私有函数。

(function() {
  function _updateTime(timeline){
    timeline.time = ...
  }

  Timeline = Backbone.Model.extend({
    url: 'servertime/',

    start: function(){
      this.fetch({
        success: function(timeline, response){
          _updateTime(timeline);
          setInterval(function() {
            _updateTime(timeline);
          }, 60 * 1000);
        }
      });
    }
  });

})();