gpt4 book ai didi

jquery - 在 jQuery Ajax POST 中序列化 JSON 数据包

转载 作者:行者123 更新时间:2023-12-03 22:32:20 25 4
gpt4 key购买 nike

我有一个像套接字这样的数据结构

var s = {
"a": "foo",
"b": 5,
"c": {"d": "a long string"},
"e": {
"f": {
"g": {
"h": [1, 0, -2.1, 1.43]
}
},
"i": {
"j": {
"k": [-3.2, 3.003, 0, 0]
}
}
}
};

我想将变量 s 的“a”、“b”、“c”和“e”键存储在数据库表中,以便我可以再次重建它们。我通过 jQuery Ajax POST 发送 s。这些值将被插入并存储为纯文本(“b”除外,它始终是数字)。

ajax: {
url: uri,
type: "POST",
data: s,
dataType: "json",
success: function(data, status) { .. }
}

这是我遇到的问题。在 Firebug 中我可以看到我的 post 参数……它们真的很困惑。似乎数据已经在每个元素的级别上序列化(有点像深度序列化),而我希望得到类似的东西

e={"f":{"g":{"h":[1,0,-2.1,1.43]}},"i":{"j":{"k":[-3.2,3.003,0,0]}}}

更新:相反,我得到以下内容(我已经对下面的字符串进行了转义,因此更具可读性)

a=foo&b=5&c[d]=a long string&e[f][g][h][]=1&e[f][g][h][]=0&e[f][g][h][]=-2.1&e[f][g][h][]=1.43

也许我的做法是错误的,所以请随时指导我更好的方法。

最佳答案

使用JSON.stringify方法将数据对象序列化为字符串并发布。在服务器端,只需将其按原样存储在数据库中即可。试试这个

ajax: {
url: uri,
type: "POST",
data: { data: JSON.stringify(s) },
dataType: "json",
success: function(data, status) { .. }
}

几乎所有现代浏览器都原生支持 JSON。对于本身没有它的浏览器,您可以包含 http://ajax.cdnjs.com/ajax/libs/json2/20110223/json2.js 中所需的 js。

关于jquery - 在 jQuery Ajax POST 中序列化 JSON 数据包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9013526/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com