我正在尝试在Backbone.js中运行最基本的东西,但不知何故失败了。我为将 url 模型保存到服务器而生成的代码。
urlToAdd.set({url: urlBody.value, tags:tagsToAdd});
urlToAdd.save({
success:function(){
console.log('it works');
}
});
成功将数据发送到我的php页面但是我无法获得成功事件。我哪里做错了?我仔细观察过,找不到任何东西。
这是我的模型定义:(不幸的是,因为我是骨干菜鸟,我通过检查教程应用了这个,我不知道 url 功能中的代码是否必要
var URLWithTags=Backbone.Model.extend({
initialize:function(){
console.log('URL object has been initialized');
},
defaults:{
url:'not defined',
tags:[]
},
validate:function(attributes){
//console.log(attributes.tags[0].length);
/*if(attributes.tags[0].length<1)
return "You should create at least one tag";*/
},
urlRoot:'/URLTags/manage.php',
url:function(){
var base = this.urlRoot || (this.collection && this.collection.url) || "/";
console.log("Base has been produced");
if(this.isNew())
return base;
return base+"?id="+encodeURIComponent(this.id);
},
});
答案 0 :(得分:2)
当您调用save函数时,Save应该是对象中的第二个参数。 请人们阅读文档,或者文章评论很好,简短易读。
urlToAdd.save(null,{success:function(){console.log('it works')}});
根据文件:
savemodel.save([attributes], [options]) ;
所以:
urlToAdd.save({},{success:successCallback , error:errorCallback});
修改强>
例如:
var Car,yukon,$target ;
Object.prototype.toString = function(){
return JSON.stringify(this);
};
Car = Backbone.Model.extend({
url:"/echo/json"
});
yukon= new Car({"color":"red","brand":"GM"});
$target = $("#target");
$target.append("describe yukon :",yukon.toString(),"<br/>");
yukon.save({},
{
success:function(o){$target.append("save success <br/>",o.toString())},
error:function(e){$target.append("error",e)}
}
);
其中$ target是一个jquery对象,表示id为target的div。