关于 javascript:Backbone 模型保存客户端和服务器之间的更改循环 | 珊瑚贝

Backbone Model save on change loops between client and server


在我的主干模型中,当发生更改事件时,我会调用 save。

1
2
3
4
5
6
7
8
myModel = Backbone.View.extend({

  initialize: function() {
    var self = this;
    self.model.on(“change”, function() { self.model.save(); });
  }

});

从 Backbone 文档中,我了解到 Backbone 期望从服务器返回一个 json 对象。

所以我将模型发回给客户。然后主干更新模型,这会再次触发更改事件,这会导致它再次重新保存。

防止这种行为的推荐方法是什么?

  • Change 将模型作为第一个参数传入,因此您可以将处理程序简化为:function(model) { model.save(); }(这样您就不必为 self 烦恼)。


通常在 Backbone 中,当您不希望操作产生副作用时,您只需传递一个 silent: true 选项。例如:

1
self.model.on(“change”, function() { self.model.save({silent: true}); });

我没有进行测试以确保这能解决你的问题,但我怀疑它会。

  • 它似乎对我有用,除了我使用了 self.model.save(null, {silent: true})。在这个问题上讨论了原因。


更简洁的写法是:

1
2
3
4
//inside you model
initialize: function () {
    this.on(‘change’,function(){ this.save(null,{silent: true}); });
}

如文档中的backbonejs.org/#Model-save.

第一个参数是属性,第二个是选项。


来源:https://www.codenong.com/15749725/

微信公众号
手机浏览(小程序)
0
分享到:
没有账号? 忘记密码?