ajax中参数traditional的作用

时间:2025-04-27 10:34:08

在使用ajax向后台传值的时候,有的时

$.ajax({
type: "post",
async: true,
data: {
"records": ["123","456","789"]
},
url: "xxxxx",
error: function(request) {},
success: function(data) {}
});

但是通过测试很快就会发现java后台无法取到参数,因为jQuery需要调用jQuery.param序列化参数,jQuery.param(obj, traditional )默认情况下traditional为false,即jquery会深度序列化参数对象,以适应如PHP和Ruby on Rails框架,但servelt api无法处理,我们可以通过设置traditional 为true阻止深度序列化,然后序列化结果如下:

records: ["123", "456", "789"]    =>    records=123&p=456&p=789

随即,我们就可以在后台通过request.getParameterValues()来获取参数的值数组了,如下:

$.ajax({
type: "post",
async: true,
traditional: true,
data: {
"records": ["123","456","789"]
},
url: "xxxxx",
error: function(request) {},
success: function(data) {}
});