var url="service/signProcess.aspx";
//sets the important hidden field of the form by which server decides what to send
$('#hdnReqType2').val('sign87162');
var data=$("#frmLogin").serializeArray();
var success=function(rdata, textStatus, jqXHR) {
console.log(rdata);
};
var fail=function(jqXHR, textStatus, errorThrown) {
console.log("Error" + errorThrown + " " + textStatus);
}
$.post(url,data,success,"text").fail(fail);
我在 chrome 中打开的页面"http://fsa.citop.in/lnct/"的控制台中使用它(当页面的登录表单为空时)并获得一个 JSON 字符串作为响应。
我在 https://api.jquery.com/serializeArray/发现 serializeArray() 返回一个具有名称和值的对象数组。所以当我使用
var data=[{name :"txtLogId",value: ""},{name:"txtLogPass",value: ""},{name:"hdnReqType2",value: "sign87162"}];
我认为它等同于 $("#frmLogin").serializeArray() 返回的对象。服务器给了我一个HTML页面作为回应。
我尝试使用数据变量的两个版本进行控制台.log(data),但找不到任何区别。请解释一下数据版本与 serailizeArray() 的正确等效对象之间的区别。
成功回调中的数据参数是响应对象 (JSON)。成功函数之前的数据变量与成功回调中的数据参数冲突。我建议您更改数据变量的名称或更改成功函数中数据参数的名称。
var url="service/signProcess.aspx";
//sets the important hidden field of the form by which server decides what to send
$('#hdnReqType2').val('sign87162');
var data=$("#frmLogin").serializeArray();
var success=function(dat_a, textStatus, jqXHR) {
console.log(dat_a);
};
var fail=function(jqXHR, textStatus, errorThrown) {
console.log("Error" + errorThrown + " " + textStatus);
};
$.post(url,data,success,"text").fail(fail);
在上面的代码中,我将成功回调函数中的数据参数更改为dat_a。