如何用AJax提交name[]數組?


今天開發的時候遇到了這么一個問題:Jquery的Ajax如何提交[name][]數組呢?眾所周知 name后面加[]可以直接向服務器傳輸數組,但是Ajax不行,直接使用name[]會直接報錯。

示例:

        $.ajax({
            url:"${ctx}/addcart",
            type:"post",
            data:{“name[]”:$(".pid").val()},
            dataType:"text",
            traditional : true,
            success:function (data) {
                if (data != "0"){
                    $(".cartlist span").text(Number($(".cartlist span").text())+Number(data));
                    Showbo.Msg.alert("已經添加到購物車");
                }else{
                    window.location.href="${ctx}/login";
                }
            }
        })

 有大神提示說可以把form序列化提交

        $.ajax({
            url:"${ctx}/addcart",
       cache: true, type:"post", data:$('#yourformid').serialize(), dataType:"text", traditional : true, success:function (data) { if (data != "0"){ $(".cartlist span").text(Number($(".cartlist span").text())+Number(data)); Showbo.Msg.alert("已經添加到購物車"); }else{ window.location.href="${ctx}/login"; } } })

 然並卵,仍然會報400

我的處理方式:

        $.each($(".pid").serializeArray(), function(i, field){
            pid.push(field.value);
        });
        $.ajax({
            url:"${ctx}/addcart",
            type:"post",
            data:{pid:pid},
            dataType:"text",
            traditional : true,
            success:function (data) {
                if (data != "0"){
                    $(".cartlist span").text(Number($(".cartlist span").text())+Number(data));
                    Showbo.Msg.alert("已經添加到購物車");
                }else{
                    window.location.href="${ctx}/login";
                }
            }
        })
    }

 其實很迷,不知道為什么加了中括號就呵呵


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM