3

您好,我有一个使用 jQuery UJS for rails 远程提交的表单。我绑定到 beforeSend 事件以允许我修改提交到服务的数据。它不工作。这是我在 beforeSend 中的内容:

 settings.data = JSON.stringify({
      'list_item[title]' : 'hi?? there'
 })

这行不通。在服务器日志中,我看到了这个:

Started POST "/lists/9/list_items" for 127.0.0.1 at 2011-10-24 14:04:36 -0700
  Processing by ListItemsController#create as JSON
  Parameters: {"{\"list_item"=>{"title"=>{"\":\"hi?? there\"}"=>nil}}, "list_id"=>"9"}

知道我做错了什么吗?我想使用不在表单中的添加字段来自定义 settings.data。谢谢

4

1 回答 1

2

您无需对任何内容进行字符串化即可将其放入settings.data. data:_

要发送到服务器的数据。如果还不是字符串,则将其转换为查询字符串。它附加到 GET 请求的 url。[...] 对象必须是键/值对。

你正在做的是把这个字符串:

"{"list_item[title]":"hi?? there"}"

intodata但该字符串不是查询字符串,所以事情会变得混乱。您应该能够简单地将您的 JavaScript 对象分配给settings.data

settings.data = { 'list_item[title]' : 'hi?? there' };

让 jQuery 从那里整理出来。


基于证据而非文件的更新:

然而,进一步的调查表明这不起作用。如果我发送一个 GET 请求,我所做的任何更改都将settings.data被忽略,但如果我发送一个 POST 请求,则更改为settings.data坚持,但您必须使用查询字符串格式通过以下方式获得任何合理的信息:

settings.data = encodeURIComponent('list_item[title]')
              + '='
              + encodeURIComponent('hi?? there');

settings.data结合 POST 请求的版本让我知道:

Parameters: {"list_item"=>{"title"=>"hi?? there"}}

在服务器上,这看起来就像你所追求的。如果要保留一些原始参数,则必须手动解包并重新打包查询字符串。

于 2011-10-24T21:20:08.930 回答