您的位置:首页 > Web前端 > JavaScript

《开始学Backbone.js》之第三章Backbone Models与Collections(五)

2015-01-10 16:24 429 查看
本文内容接上篇博客内容


模型验证

Backbone提供为模型的数据提供了一个验证机制,意味着可以在模型中包含判断模型的状态是否正确的所有逻辑,而不用通过外部的JavaScript或表单处理代码。

如果提供了验证函数,那么该函数会在每次调用.save方法时执行,而且在提供了{validate:true}作为可选参数的set/unset操作过程中也会执行该验证函数。

假设我们的Book模型坚持name属性必须存在且year属性的值需是2000年以后。该规则的一个验证方法可以写成:
Book = Backbone.Model.extend({
initialize: function(){},
defaults: function(){},
printDetails: function(){},
validate: function(attrs){
if(attrs.year < 2000){
return 'Year must be after 2000';
}
if(!attrs.name){
return 'A name must be provided';
}
}
});


在操作模型的过程中如果违反这些规则,则试图修改属性值的操作将失败。

//试图把year属性设置为2000年之前
thisBook.set('year', 1999, {validate: true});
console.log('Check year change: ' + thisBook.get('year'));
//试图从模型中移除name属性
thisBook.unset('name', {validate: true});
console.log('Check if name was removed ' + thisBook.get('name'));


当检测到一个验证错误时,会触发一个事件。通过增加一个“invalid”事件监听,可以提供验证失败的反馈信息。和所有事件监听一样,这个应该加在initialize函数中。

Book = Backbone.Model.extend({
initialize: function(){
this.on('invalid', function(model, error){
console.log('**Validation Error : ' + error + '**');
});
}
});


如果不设置验证标识,通过set设置属性时验证函数就不会执行。然而,任何时候你都可以通过isValid()方法来检查模型是否有效。

//检查模型是否有效
console.log('Is model valid: ' + thisBook.isValid());
//在不使用验证标识情况下破坏有效性规则
thisBook.set('year', 1998);
//检查模型是否有效
console.log('Is model valid: ' + thisBook.isValid());


本篇内容翻译自《Beginning Backbone.js》,原著作者James
Sugrue。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐