我得到了这个非常简单的访客模型
define([
], function() {
Guest = Backbone.Model.extend({
urlRoot : ftd.settings.rest + '/guest',
defaults: {
id : '',
name : '',
accessToken : ''
},
validate: function( attr ) {
var errors = [];
if(attr.name.length < 4) {
errors.push({message : "You nickname, must be atleast 4 chars", name : 'guestNickname'});
}
return errors;
}
});
return Guest;
});
然后我有一个首页视图,访客注册,基本上这会在点击提交按钮时发生。
createGuest: function( ev ) {
ev.preventDefault();
// Get nickname.
var guest = new Guest();
guest.bind( 'error', function( model, errors ) {
_.each( errors, function( err ) {
$('input[name=' + err.name + ']').addClass('invalid');
// add a meesage somewhere, using err.message
}, this );
});
guest.save({
'name' : $('input[name="guestNickname"]').val()
}, {
wait:true,
success:function(model, response) {
console.log('Successfully saved!');
},
error: function(model, error) {
console.log(error);
}
});
},
所以我从输入元素中取名,然后将其放入save方法中。问题是,Backbone不向服务器发送请求,只是触发错误事件。其中打印一个空的错误数组。 我做错了什么?
答案 0 :(得分:1)
如果validation成功,你应该不返回任何内容。
由于您返回一个空数组,因此它假定该数组是验证错误。
试试这个:
validate: function( attrs ) {
var errors = [];
if(attrs.name.length < 4) {
errors.push({message : "You nickname, must be atleast 4 chars", name : 'guestNickname'});
}
if(errors.length > 0){
return errors;
}
}