今天開發的時候遇到了這麼一個問題:Jquery的Ajax如何提交[name][]數組呢?衆所周知 name後面加[]能夠直接向服務器傳輸數組,可是Ajax不行,直接使用name[]會直接報錯。javascript
示例:java
$.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
$.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"; } } }) }
其實很迷,不知道爲何加了中括號就呵呵post