javascript – Backbone.js的模型或视图中类似私有的属性

前端之家收集整理的这篇文章主要介绍了javascript – Backbone.js的模型或视图中类似私有的属性前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
是否有可能在模型中拥有私有属性?就像(构造函数)函数中的本地声明的变量一样,没有附加到它,但只在(构造函数)函数中定义的任何内容声明本地和可见.
没有BB视图的示例:
function MyView(aModel){

  var $internalInput = $('<input>');

  this.render: function($where){
     $internalInput.val(aModel.get('SomeProperty'));
     $where.append($('<div class="inputWraper">').append($internalInput));
  };
  this.toggleReadonly: function() {
    toggle $internalInputs readonly attribute
  }
  ...
  + Code to bind input.val to some aModel property(ies) and setup events
  ...
}

请注意,外部世界无法访问internalInput,也无法访问aModel(至少通过MyView).
所以如果我想使用Backbone.View来实现上面的MyView,我该如何做并保持$internalInput’private’?

解决方法

您应该能够通过在定义Backbone对象时传递IIFE来扩展私有数据,而不仅仅是普通对象.例如:
var Thing = Backbone.Model.extend((function () {
  var foo = "Private data!";

  return {
    bar: function () {
      console.log(foo);
    }
  };
})());

猜你在找的JavaScript相关文章