在Web開發中,前台和背景的資料互動是十分頻繁的, 而JQuery對Ajax進行了封裝,使得前台向背景發送資料變得十分簡單。
假如背景有一個Java類User,來接收并封裝資料
public class User{
private Interger id;
private String name;
private String sex;
}
一、簡單的資料格式
$.ajax發送資料的幾種形式
//1 直接在url中傳遞
$.ajax({
type: "POST",
url: "/testAjax/addUser?id=1&name=zhangxiaofan&sex=male",
success:function(data){
//TODO
}
})
//2 html頁面from表單序列化
var formData = $("#form").serialize();
$.ajax({
type: "POST",
url: "/testAjax/addUser",
data: formData,
success:function(data){
//TODO
}
})
//3 拼接data字元串
var formData = $("#form").serialize();
$.ajax({
type: "POST",
url: "/testAjax/addUser",
data: "id=1&name=zhangxiaofan&sex=male",
success:function(data){
//TODO
}
})
//4 簡單的js對象
var userData = {
id:,
name:zhangxiaofan,
sex:male
}
$.ajax({
type: "POST",
url: "/testAjax/addUser",
data: userData, //或者data:{id:1,name:zhangxiaofan,sex:male}
success:function(data){
//TODO
}
})
針對以上方式,背景資料的擷取(SpringMvc架構)
@RequestMapping(value = "/testAjax")
public class UserController{
// 1 将User放到參數中,架構進行封裝
@RequestMapping(value = "/addUser")
public String addUser(User user) {
//TODO
}
// 2 自己擷取
@RequestMapping(value = "/addUser")
public String addUser(HttpServletRequest request) {
String id = request.getParameter("id");
String name = request.getParameter("name");
String sex= request.getParameter("sex");
}
}
二、複雜的資料格式
複雜的資料一般采用JSON格式來傳輸,并且Java對JSON格式的資料也都有很好的支援,如JSON-lib的JSONArray和JSONObject、jackson等技術。
注意: 前背景傳輸的JSON資料一般是JSON對象序列化的字元串,而不是直接傳遞JSON對象。
//1 JSON對象
var user = {id:,name:"zhangxiaofan",sex:"male"};
//2 自己拼接JSON字元串
var userStr = '{"id":"","name":"zhangxiaofan","sex":"male"}';
//3 JSON.stringify(data) JS方法序列化JSON對象
var userStr = JSON.stringify(user);
//1 将JSON字元串作為value值,背景借助JSON解析工具
var userStr = '{"id":"1","name":"zhangxiaofan","sex":"male"}';
$.ajax({
type: "POST",
url: "/testAjax/addUser",
data: "user="+userStr ,
success:function(data){
//TODO
}
})
//背景代碼
String json = request.getParameter("link");
JSONObject j = JSONObject.fromObject(json);
System.out.println(j.get("linkId"));
//2 結合SpringMvc的@RequestBody,@RequestBody需要把所有請求參數作為json解析,不能包含key=value這樣的寫法在請求url中,可以輕易的将一個對象或者數組傳到Java端,使用@RequestBody即可綁定到對象或者List/數組
//(1)對象
var user = {
id:,
name:"zhangxiaofan",
sex:"male"
}
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8", //需要設定contentType
url: "/testAjax/addUser",
data: JSON.stringify(user) ,
success:function(data){
//TODO
}
})
//背景
@RequestMapping(value = "/addUser")
public String addUser(HttpServletRequest request,@RequestBody User user) {
}
//(2)數組
var users=[];
var user1={id:,name:tom,sex:cat};
var user2={id:,name:tom2,sex:cat};
users.push(user1);
users.push(user2);
$.ajax({
type: "POST",
contentType: "application/json; charset=utf-8", //需要設定contentType
url: "/testAjax/addUser",
data: JSON.stringify(users) ,
success:function(data){
//TODO
}
})
//背景
@RequestMapping(value = "/addUser")
public String addUser(HttpServletRequest request,@RequestBody List<User> user) {
//上面也可以将List<User>改為User[]數組
}