1. 传递JSON参数
vardata = {'id':1,'name':'abc'};
$.ajax({
type:'post',
url:'homePageAction.do?testAJax',
contentType:'application/x-www-form-urlencoded',
data:JSON.stringify(data),
success:function(data){
console.log("aaaaaaaaaaa")
console.log(data.msg);
},
error:function(){
}
});
// @RequestMapping(params= "testAJax")
// public voidtestAjax(@RequestParam String id,String name,HttpServletRequest req){
// Stringid2 = req.getParameter("id");
// Stringname2 = req.getParameter("name");
// System.out.println("1111");
// System.out.println("2222");
// }
2. 传递JSON对象或JSON数组(后台接收使用EventInfo[],而不是List<EventInfo> list)
vardata = [{'id':1,'name':'abc'},{'id':2,'name':'def'},{'id':3,'name':'ghi'}];
console.log(JSON.stringify(data));
$.ajax({
type:'post',
url:'homePageAction.do?testAJax',
contentType:'application/json',
data:JSON.stringify(data),
success:function(data){
console.log(data.msg);
console.log(data.obj.id);
console.log(data.obj.name);
},
error:function(){
}
});
// @RequestMapping(params= "testAJax")
// @ResponseBody
// publicJSONObject testAjax(@RequestBody EventInfo[] ei,HttpServletRequest req){
// Longid1 = ei[0].getId();
// Stringname1 = ei[0].getName();
// JSONObjectjo = new JSONObject();
// jo.put("msg","return success");
// jo.put("obj",ei[0]);
// return jo;
// }
3. 传递JSON数组,后台用List接收
前端Ajax传参数:
[ "0866282192144020" ]
后端Spring方法接收参数:
@RequestParam("carnums[]") List<String> carnums
4. 后台返回前台JSON,需要在返回方法上加上@ResponseBoby,代表将JSON数据放到Http Boby中返回
返回值标识了@ResponseBody,SpringMVC将使用StringHttpMessageConverter的write()方法,将结果作为String值写入响应报文,当然,此时canWrite()方法返回true。
关于HttpMessageConverter和@RequestBody、@ResponseBody的关系请看我另一篇文章。
本文介绍如何使用Ajax发送JSON格式的数据到服务器,并演示了不同类型的JSON数据传递方式,包括简单的JSON对象、JSON数组以及如何在后台正确接收这些数据。
1115

被折叠的 条评论
为什么被折叠?



