2

我还有另一个与 PUT 和 POST 请求有关的问题。所以,这里我有一个表单,其中包含以下字段:“名称”和“链接”。

在提交该表单时,我无法在执行 this.model.save(); 时将该表单发布到服务器;

另外,我如何理解模型何时调用 POST 以及何时调用 PUT 请求?由于我的 api 响应中没有任何“id”属性,所以我的模型也没有任何 id。

那么如何在单击“提交”按钮时将表单字段值作为 POST 请求传递?

另外,有没有一种方法可以调用请求:例如:如果我点击表单的“更新”按钮,我将从我的模型中调用一个函数

updateModel:function(options){
this.update("update","/messages",[options])
}

或者可以像这样读取获取请求

getModel:function(options){
this.update("read","/messages",[options])
}
4

1 回答 1

2

save 方法会根据 的返回值来决定是 POST 还是 PUT isNew()。此方法通常仅检查是否id已填充。您可以覆盖它以使用其他指标。

您将提交时的表单字段值直接传递到您的保存方法中。像这样的东西:

//In your view
events : {"submit" : "onSubmit"},
onSubmit : function(e) {
  e.preventDefault();
  this.model.save({name: this.$("#name").val()}, {
    success : function (newModel) { /* Do something here. */ }
  });
}

另一种选择是使用类似的库Backbone.Modelbinder来为您处理 DOM 和模型之间的同步。

您不需要在模型上定义这些新方法。相反,您应该url在模型或相应的控制器上定义适当的方法。然后你可以使用正常的fetchsave方法来处理你的获取/更新。

于 2012-12-07T00:09:55.750 回答