jquery serializeArray() 等效对象

jquery serializeArray() equivalent object

本文关键字:对象 serializeArray jquery      更新时间:2023-09-26
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