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() { }); |
从 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/