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

前端之家收集整理的这篇文章主要介绍了javascript – Backbone.js的模型或视图中类似私有的属性前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
是否有可能在模型中拥有私有属性?就像(构造函数)函数中的本地声明的变量一样,没有附加到它,但只在(构造函数)函数中定义的任何内容声明本地和可见.
没有BB视图的示例:
  1. function MyView(aModel){
  2.  
  3. var $internalInput = $('<input>');
  4.  
  5. this.render: function($where){
  6. $internalInput.val(aModel.get('SomeProperty'));
  7. $where.append($('<div class="inputWraper">').append($internalInput));
  8. };
  9. this.toggleReadonly: function() {
  10. toggle $internalInputs readonly attribute
  11. }
  12. ...
  13. + Code to bind input.val to some aModel property(ies) and setup events
  14. ...
  15. }

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

解决方法

您应该能够通过在定义Backbone对象时传递IIFE来扩展私有数据,而不仅仅是普通对象.例如:
  1. var Thing = Backbone.Model.extend((function () {
  2. var foo = "Private data!";
  3.  
  4. return {
  5. bar: function () {
  6. console.log(foo);
  7. }
  8. };
  9. })());

猜你在找的JavaScript相关文章