1.ajax部分:
var arry = ['1','2','3'];
//就是最普通的jquery ajax向后台直接发送数据
$.ajax({
type:'post',
url:'/demo/path',
//traditional默认是false,如果是false,则传递的参数为:
//data[]:1
//data[]:2
//data[]:3
//这里设置为true,使传递参数变成:
//data:1
//data:2
//data:3
//不过无论哪种实际上都不影响后台接受,稍作区分即可,下面会提到
traditional: true,
data:{
data:arry
},
success:function(data){
console.info(data);
}
});
2.controller部分:
下面是controller接受数则参数的方法,需要使用RequestParam
指明value名称,正如上面所说,若传递的数据格式是data[]:3,则RequestParam的value是data[]
, 若传递的数据格式是data:3,则RequestParam的value是data
,后面既可以用List接收,也可以用数组接收.
@RequestMapping("/demo/path") //traditional为true方式
public boolean createRsp(@RequestParam(value = "data")String[] data) {
System.out.println("--data-size-"data.length);
return false;
}
@RequestMapping("/demo/path") //traditional默认是flase方式
public boolean createRsp(@RequestParam(value = "data[]")String[] data) {
System.out.println("--data-size-"data.length);
return false;
}
3.补充:
上面用到了jQuery ajax的traditional参数,他的作用是:
规定是否使用传统的方式进行序列化(参数序列化)。 默认的话traditional为false,即jquery会深度序列化参数对象,traditional 为true阻止深度序列化