我试图重写Backbone.sync,以便在每次获取模型时设置"id“属性。这样,我确信下一个model.save()将触发一个更新,而不是一个create,即使fetch()没有使用id进行响应。
Backbone._sync = Backbone.sync;
Backbone.sync = function(method, model, options) {
var params = _.clone(options);
params.success = function(model) {
if(method == 'read' && model.isNew()) {
var id = Math.floor(Math.random()*1000);
model.set({ "id": id });
}
if(options.success) options.success(model);
};
Backbone._sync(method, model, params);
}但是传递给成功函数的模型似乎不是一个骨干模型,而是一个对象。所以我不能在上面使用任何方法(比如model.isNew())。知道我做错了什么吗?
发布于 2011-10-25 23:18:01
听起来您可能想要重写Model.fetch或Model.parse,而不是Backbone.sync。Backbone.sync只使用$.ajax()选项,因此success回调只是接收来自服务器的JSON响应,而不是实例化模型。
默认的Model.fetch()回调如下所示:
options.success = function(resp, status, xhr) {
if (!model.set(model.parse(resp, xhr), options)) return false;
if (success) success(model, resp);
};这里,model引用当前实例,正如您所希望的那样。因此,您可以考虑在不存在id的情况下重写Model.fetch以添加一个id,或者可能更好的是重写model.parse(),默认情况下它是一个过路,它是用来处理服务器数据的钩子。我对您的随机数id实现并不感到兴奋,因为仍然有可能发生冲突,特别是如果您正在制作许多模型--您可以尝试使用model.cid (保证在客户机中是唯一的,尽管它可能与服务器提供的id发生冲突)或下划线的.uniqueId()
parse: function(resp, xhr) {
if (this.isNew() && !resp.id) {
resp.id = _.uniqueId('model-');
}
}发布于 2011-12-13 12:00:50
@nrabinowitz
只是为了给这件事增加一点点清晰性。我使用的是RedbeanPHP,它内置了JSON支持。一个问题是,当您创建一个对象时,它会在结果标记中返回该对象的新id,如果您想编辑新对象,就需要这个id。
// My model object is a User. (we are all Users in some way).
var User = Backbone.Model.extend(
{
url : "/user/rpc",
defaults: {
email: "email",
password: "",
admin: 0
},parse: function(resp, xhr) {
// check if the model is new, if so, set the id of this model for future requests so RedBean knows the id of this object.
if(this.new()){
this.set({"id":resp.result});
console.log(this);
}
}
}
); https://stackoverflow.com/questions/7896714
复制相似问题