微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

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);
    }
  };
})());

原文地址:https://www.jb51.cc/js/152215.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐