0

不幸的是,我似乎只得到了 jQuery 结果。我正在寻找通过 AJAX 传递参数的正确方法,不需要旧的浏览器回退,但请不要使用库。如果我错过了另一个线程,请链接=)

我正在使用 $,但它是自定义对象/无论如何,而不是 jQuery。

$.ajax({
    't':'POST',
    'u':e, 
    'd':{ajax:'1'},
    's':function(data){
        console.log(data.response);
        document.getElementById('mainc').innerHTML = data.response;
    },
    'e':function(data){
        console.log(data);
    }
});

哪个电话:

$.ajax = function(a){
if(!a.u){return false;};
a.t=a.t||"GET";
typeof a.a=='undefined'?true:a.a;
a.e=a.e||function(){return false;};
a.s=a.s||function(){return true;};
var x=new XMLHttpRequest();
x.open(a.t,a.u,a.a);
x.onreadystatechange=function(){
    if(x.readyState===4){
        if(x.status===200){
            a.s(x);
        }else{
            a.e(x);
        }
    }
};
a.t==="post" ? x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded") : null;
x.send(a.d);

}

x.send(a.d)应该通过{ajax:'1'}。我试过{'ajax':'1'}了,也'ajax=1'一样。不知道为什么我尝试传递的参数都没有使它成为服务器端。我非常确定参数没有到达服务器,尽管请求似乎可以毫无问题地发送和接收。

4

2 回答 2

1

XMLHttpRequest.send()如果您设置,则不接受 javascript/JSON 对象x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded")

您应该格式化为此处提到的 urlencoded 变量:

Javascript 对象的查询字符串编码

x.setRequestHeader("Content-Type", "application/json")像建议的另一个答案一样使用。

还:

a.t==="post"应该是a.t==="POST"因为它不会因为区分大小写检查而更改请求标头。

完整的工作代码(带有 urlencoded 数据):

$ = {}

$.ajax = function(a){
if(!a.u){return false;};
a.t=a.t||"GET";
typeof a.a=='undefined'?true:a.a;
a.e=a.e||function(){return false;};
a.s=a.s||function(){return true;};
var x=new XMLHttpRequest();
x.open(a.t,a.u,a.a);
x.onreadystatechange=function(){
    if(x.readyState===4){
        if(x.status===200){
            a.s(x);
        }else{
            a.e(x);
        }
    }
};
a.t==="POST" ? x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded") : null;
x.send(a.d);

}    

$.ajax({
    't':'POST',
    'u':'/', 
    'd':"ajax=1",
    's':function(data){
        console.log(data.response);
        document.getElementById('mainc').innerHTML = data.response;
    },
    'e':function(data){
        console.log(data);
    }
});
于 2012-10-22T21:45:45.857 回答
1

尝试将请求标头设置为

x.setRequestHeader("Content-Type", "application/json")

看看这个

于 2012-10-22T21:35:55.270 回答