我正在使用 AJAX 提交序列化表单。传递给 action.php 的数据最终包含 %5B%5D 而不是 []。有没有办法取回 [],或者数据是否能够在 action.php 中以相同的方式处理(即像数组一样)?

表单通过以下方式序列化:

var form_data = $("#form").serialize();

然后我通过 $.ajax 发送它:
$.ajax({
    type: "POST",
    url: "action.php",
    data: {
        form_data: form_data,
        FrmSubmit: 'SubmitButton'
    },
    cache: true,
    success: function (html) {

        $("#show").html(html);
        alert("form success");
    }
});

传递给 action.php 的理想数据应该是这样的: name=JohnSmith&color[]=blue&color[]=yellow&meal[]=chicken&meal[]=fish
我得到了:name=JohnSmith&color%5B%5D=blue&color%5B%5D=yellow&meal%5B%5D=chicken&meal%5B%5D=fish
附加问题:
我也尝试过 .param(),但无法真正确定接收到的数据的正面或反面。每个字母最终都被编码在一个 key 中。谁能解释为什么会这样?

最佳答案

所以你正在做的是有效地对数据进行双重序列化。

一次在这里:

var form_data = $("#form").serialize();

然后再次在这里:
$.ajax({
    type: "POST",
    url: "action.php",
    data: {
        form_data: form_data,
        FrmSubmit: 'SubmitButton'
    },
    cache: true,
    success: function (html) {

        $("#rsvp_sub").html(html);
        alert("form success");
    }
});

当您将对象传递给 $.ajaxdata 参数时,它会对其进行序列化和编码。

所以……不要那样做。一种选择是这样做:
var form_data = $("#form").serialize() + "&FrmSubmit=SubmitButton";
$.ajax({
    type: "POST",
    url: "action.php",
    data: form_data,
    cache: true,
    success: function (html) {

        $("#rsvp_sub").html(html);
        alert("form success");
    }
});

请注意,如果 FrmSubmitSubmitButton 包含除 A-Z、a-z、0-9 之外的任何内容(我是保守的),或者如果您不控制它们包含的内容,您会想要使用 encodeURIComponent :
var form_data = $("#form").serialize() + "&" +
    encodeURIComponent('FrmSubmit') + "=" +
    encodeURIComponent('SubmitButton');

关于php - JQuery - 在 .serialize() 中摆脱 %5B%5D,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/24048055/

10-10 10:21