我试图通过ajax从客户端(javascript)向服务器(php)发送数据。 我有一个看起来像这样的对象:
sinfo={
topic_title:title,
topic_id: tid,
section_name:section_name,
section_id: fid,
circuito: "fc",
from_mid:mid,
sito:site,
st: st,
tags:{"m4148305":{"post_id":987649,"from_id":1}}
}
我想将该对象传递给服务器。 我知道的唯一方法是使用JQuery,所以我尝试了类似的东西:
$.post(baseurl+"/server/?act=post",sinfo,function(e)
{
sessionStorage.PixelTagSystemTagRequest="false";
});
它适用于Chrome和Safari。但Firefox显示奇怪的错误,如:
在HTMLElement上调用事件.click() 没有实现接口
解决方案应该很简单:更新JQuery,不幸的是我不允许这样做。 所以我尝试了一个Pure JS解决方案
var fd = new FormData(), lol, xml;
for(lol in sinfo)
{
fd.append(lol,sinfo[lol]);
//alert(lol+" = "+sinfo[lol]);
}
xml = new XMLHttpRequest();
xml.open("POST",baseurl+"/server/?act=post");
xml.onreadystatechange=function()
{
if(xml.readyState==4)
{
sessionStorage.PixelTagSystemTagRequest="false";
alert(xml.responseText);
}
};
xml.send(fd);
但是 sinfo.tags 仍然是一个对象,我不知道如何将该属性传递给服务器。
P.s:我试图避免对对象进行字符串化(使用JSON),所以我不必更改php代码。
答案 0 :(得分:0)
如果要使用FormData,可以添加一些代码,如:
for(lol in sinfo)
{
if (lol == "tags") {
for (lok in sinfo[lol]) {
fd.append("tags[" + lok + "]", sinfo[lol][lok];
}
} else {
fd.append(lol,sinfo[lol]);
}
}