Backbone中的Model使用方法

来源:互联网 发布:windows永久免费vps 编辑:程序博客网 时间:2024/05/16 18:53

通过Backbone.Model.extend()的形式,创建一个Model,该Model可以作为一个构造函数用于创建更多的Model实例。

 1 初始化方法:initialize

initialize: function(){}

 2 默认值:defaults

defaults: {}

3 存取器:get/set/unset

model.get('key');model.set('key', value);model.set({'key', value}, {silent: true});model.unset('key')

4 attributes

model.attributes

 5 事件监听--初始化时整个model监听change事件

initialize: function(){    this.on('change', function(){    }}

 6 事件监听--监听model特定字段的change事件

initialize: function(){    this.on('change:title', function(){    }}

 7 模型验证

validate: function(attrs) {   //如果所有属性通过验证,不返回任何信息;如果有属性不通过验证,应返回相应的错误信息}

   默认情况下,两种方式会触发验证,一是调用模型的save()方法持久化数据时;二是调用set()方法且设置{validate: true}时。

   当验证出错时,validate返回的错误信息会设置到模型的validationError属性上。


 8 model克隆

newModel = oldModel.clone();
如果model直接赋值,新model的修改会影响原来model的值。而使用clone方法则不会出现这种情况。

9 判断model中是否含有某个属性

model.has('key');

10 移除model中的所有属性

model.clear();

11 转义model中属性的值

model.escape('key');


 12 idAttribute设置model的ID

 

 13 几个方法的区别

   this.model  返回的是Backbone的对象,包含了Backbone的其他一些内置属性;

   this.model.toJSON()  返回用户自定义的对象内容,JavaScript对象的形式;相当于this.model.attributes的内容;

   JSON.stringify(this.model)  返回用户自定的对象内容,JSON String的形式。







0 0
原创粉丝点击