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

ple*_*sig 3 javascript backbone.js underscore.js

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

我的主要问题:

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

model:{    
"eventid":"3",
"eventuniqueid":"abasdfasfafd",
"type":"Birthday",
"name":"Add"}
Run Code Online (Sandbox Code Playgroud)

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

eventid:"3",
eventuniqueid:"abasdfasfafd",
type:"Birthday",
name:"Add"
Run Code Online (Sandbox Code Playgroud)

这可能很容易吗?

Loa*_*oof 7

容易?不需要.您必须重新定义Model#sync方法的行为(该函数在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} : {};
}
Run Code Online (Sandbox Code Playgroud)

通过删除我说的最后一行,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));
}
Run Code Online (Sandbox Code Playgroud)

编辑:
事实上,通过在保存时以您喜欢的方式传递数据,您应该没问题(您将拥有数据和Backbone的模型参数).

myModel.save({}, {data: myModel.toJSON()});
Run Code Online (Sandbox Code Playgroud)