如何将对象发送到PHP

时间:2014-10-31 00:11:45

标签: javascript php jquery arrays ajax

我试图通过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代码。

1 个答案:

答案 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]);
    }
}