首页 > 代码库 > backbonejs中的模型篇(三)
backbonejs中的模型篇(三)
一:在模型中使用嵌套属性
Backbone的扩展插件 Backbone-Nested下载并添加引用
1:定义一个新的模型对象,使用Backbone.NestedModel作为其基类对象
var _model = Backbone.NestedModel.extend({...}) var testObj = new _model()
2: 使用‘.‘操作符来获取或设置嵌套属性值
testObj.set({ ‘name.title‘: ‘Mr.‘, ‘name.alias‘:‘test02‘}) testObj.set({ name:{ first:‘joan‘, last:‘ Smith‘, middle:{ initial:‘P‘, full:‘Peter‘ } } })
testObj.get(‘name.middle.full‘) //PetertestObj.get(‘name.title‘) // Mr.testObj.get(‘name.middle‘) //{initial:‘P‘,‘full‘:‘Peter‘}
3:嵌套的属性数组
//设置属性数组testObj.set({ ‘addresses‘:[ {city:‘shanghai‘, state:‘sh‘} {city:‘changsha‘, state:‘hn‘} ] })//或者使用.{}来设置数组里面的属性值testObj.set({‘addresses[1].state‘:‘hunan‘})//获取属性数组testObj.get(‘addresses[0].state‘) //sh
Backbone-Nested也重写了get(),set(),has(),toJSON方法,还提供了新的add(),remove()方法
如:add方法添加一个新元素到数组
testObj.add(‘addresses‘,{city:‘yueyang‘,state:‘hunan‘})
remove方法删除一个新元素 testObj.remove(‘addresses[1]‘)
4:为事件change绑定回调函数
testObj.bind(‘change:addresses[0].city‘, function(model,value){
console.log(value); //当addresses[0].city 发生改变时, 输出新的值
})
testObj.set(‘addresses[0].city‘,‘xx‘) //触发绑定事件
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。