今天開發的時候遇到了這么一個問題: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";
}
}
})
}
其實很迷,不知道為什么加了中括號就呵呵
