這次帶給大家js傳遞json到controller該如何操作,js傳遞json到controller的注意事項有哪些,下面就是實戰案例,一起來看一下。
Spring MVC在接收集合請求參數時,需要在Controller方法的集合參數裡前加入@RequestBody,而@RequestBody預設接收的enctype (MIME編碼)是application/json,因此發送POST請求時需要設定請求報文頭訊息,否則Spring MVC在解析集合請求參數時不會自動的轉換成JSON資料再解析成對應的集合。
以下列舉接收List、List、List
收到List集合參數:
1、頁面js程式碼:
var idList = new Array();
idList.push(“1”);
idList.push(“2”);
idList.push(“3”);
var isBatch = false;
$.ajax({
type: "POST",
url: "<%=path%>/catalog.do?fn=deleteCatalogSchemes",
dataType: 'json',
data: {"idList":idList,"isBatch":isBatch},
success: function(data){
…
},
error: function(res){
…
}
});
登入後複製
2、Controller方法:
@Controller
@RequestMapping("/catalog.do")
public class CatalogController {
@RequestMapping(params = "fn=deleteCatalogSchemes")
@ResponseBody
public AjaxJson deleteCatalogSchemes(@RequestParam("idList[]") List<String> idList,Boolean isBatch) {
…
}
}
登入後複製
接收List、User[]集合參數:
#1、User實體類別:
public class User {
private String name;
private String pwd;
//省略getter/setter
}
登入後複製
#2、頁面js程式碼:##
var userList = new Array();
userList.push({name: "李四",pwd: "123"});
userList.push({name: "张三",pwd: "332"});
$.ajax({
type: "POST",
url: "<%=path%>/catalog.do?fn=saveUsers",
data: JSON.stringify(userList),//将对象序列化成JSON字符串
dataType:"json",
contentType : 'application/json;charset=utf-8', //设置请求头信息
success: function(data){
…
},
error: function(res){
…
}
});
登入後複製
登入後複製
3、Controller方法:
@Controller
@RequestMapping("/catalog.do")
public class CatalogController {
@RequestMapping(params = "fn=saveUsers")
@ResponseBody
public AjaxJson saveUsers(@RequestBody List<User> userList) {
…
}
}
登入後複製
如果想要接收User[]數組,只需要把saveUsers的參數類型改為@RequestBody User[] userArray就行了。 接收List