使用emulatejson而不将模型作为参数的主干

时间:2013-04-05 14:51:23

标签: javascript backbone.js underscore.js

我有一个模型,它是一种“动作”,当用户点击按钮,设置和删除事件时发生。事件本身是另一个模型和另一个集合,所以从技术上讲,我可以将此请求发送到API,而不是它甚至是模型,因为我可以在事件列表发生更改时单独更新它。无论如何,这不会解决我将数据发送到服务器的问题。

我的主要问题:

当我使用emulateJSON = true来确保POST作为application / x-www-form-urlencoded类型发送时,我的所有数据都包含在模型参数中:

model:{    
"eventid":"3",
"eventuniqueid":"abasdfasfafd",
"type":"Birthday",
"name":"Add"}

我想要的是将每个作为表单参数,如下所示:

eventid:"3",
eventuniqueid:"abasdfasfafd",
type:"Birthday",
name:"Add"

这可能很容易吗?

1 个答案:

答案 0 :(得分:6)

容易吗?不。您必须重新定义Model#sync method的行为(该功能在Backbone.sync中定义)。没有参数允许您自定义它。

您必须更改该部分:

// For older servers, emulate JSON by encoding the request into an HTML-form.
if (options.emulateJSON) {
  params.contentType = 'application/x-www-form-urlencoded';
  params.data = params.data ? {model: params.data} : {};
}

通过删除我说的最后一行,params.data就在之前定义:

if (options.data == null && model && (method === 'create' || method === 'update' || method === 'patch')) {
  params.contentType = 'application/json';
  params.data = JSON.stringify(options.attrs || model.toJSON(options));
}

修改
实际上,通过在保存时以您喜欢的方式传递数据,您应该没问题(您将拥有数据和Backbone的模型参数)。

myModel.save({}, {data: myModel.toJSON()});