1. Ajax接收JSON資料
JSON:JavaScript物件表示法(JavaScript Object Notation),JSON是一種存盤和交換文本資訊的語法,因為JSON比XML更輕量,效率更高,更易決議,所以在Ajax中前后臺傳輸資料一般都使用的是JSON格式,
1.1.JSON與XML的對比
|
資料格式 |
特點 |
|
JSON |
JSON 是純文本 JSON 具有“自我描述性”(人類可讀) JSON 具有層級結構(值中存在值) JSON 可通過 JavaScript eval()進行決議 JSON 資料可使用 AJAX 進行傳輸 |
|
XML |
XML是檔案結構,節點復雜 XML可以通過JavaScript決議,需要回圈遍歷DOM讀取節點資訊 XML厚重且讀取效率低 |
1.2.JSON語法
JSON語法是JavaScript語法的子集,
JSON語法的規則:
- 資料在名稱/值對中
- 資料由逗號分隔
- 花括號保存物件
- 方括號保存陣列
JSON資料的書寫格式時:名稱/值對,即欄位名稱(在雙引號中),后面一個冒號,對應是值,JSON的值可以是:數字(整數或浮點數)、字串(在雙引號中)、邏輯值(true或false)、陣列(在方括號中)、物件(在花括號中)、null,
常見的JSON語法書寫:
<script type="text/javascript">
var json01 = {}; //json的第一種寫法:json物件
var json02 = []; //json的第二種寫法:json陣列
// json物件一般寫法
var json03 = {
name:"張小三",
age:45,
sex:true
};
// json物件標準格式
var json03_1 = {
"name":"張小三",
"age":45,
"sex":true
};
//json陣列
var json04 = [{
name:"張小三",
age:45,
sex:true
},{
name:"李華",
age:20,
sex:false
}
];
var json05 = [{
name:"張小三",
age:45,
sex:true,
department:{
id:1,
name:"IT部",
employees:[
{name:"xxx", age:23},
{name:"yyy", age:24}
]
}
},{
name:"李華",
age:20,
sex:false
}
];
</script>
1.3.JSON檔案
- JSON 檔案的檔案型別是 ".json"
- JSON 文本的 MIME 型別是 "application/json"
1.4.JSON使用
JSON最常見的用法之一,是從web服務器上讀取JSON格式的字串資料,將JSON資料轉化為JavaScript物件,然后在網頁上使用該資料,
轉化JSON格式字串為JSON物件的方式有兩種:
①使用JavaScript函式eval()
<script type="text/javascript">
//最標準的json格式:key必須要加雙引號
var formatJson = {
"name" : "黃小邪",
"age" : 23,
"sex" : true
};
//①jsonStr轉json物件方式一:
//eval:計算javascript字串,并把它作為腳本代碼來執行
//前臺接收到的是json字串格式,拿資料需要把字串轉化成json物件
var jsonStr = '{name : "黃小邪", age : 23, "sex" : true}';
//注意:使用eval轉換jsonStr,必須前后加括號,這里不區分是否標準格式
var jsonObj = eval("("+ jsonStr +")");
console.debug(jsonObj);
</script>
②使用JSON決議器
eval()函式可以編譯并執行任何JavaScript代碼,使用eval()隱藏了一個潛在的安全問題,
使用JSON決議器將JSON字串轉換為JavaScript物件是更安全的做法,
JSON決議器只能識別JSON字串文本,不會編譯腳本,相對決議速度更快,具有拿來即用的便捷,
使用JSON決議器:
①需要匯入JSON轉換JSONObj相關jar包;

②轉換物件可以是任何JSON字串格式的文本,但是必須是標準的JSON格式:
//②jsonStr轉json物件方式二: var jsonStr2 = '{"name" : "黃小邪", "age" : 23, "sex" : true}'; //注意:使用JSON.parse轉換jsonStr必須保證jsonStr是標準格式的字串 var jsonObj2 = JSON.parse(jsonStr2); console.debug(jsonObj2);
1.5.JSON與Ajax實作二級聯動實體
這里使用JSON字串操作并向前臺傳輸JSON格式的資料來展示JSON與Ajax之間的操作實作,
后臺:
虛擬了兩個省、市Domain并提供加載獲取省、市的方法供Servlet向前臺傳輸資料:
City.java:
/** * 城市物件 * */ public class City { private Long id; private String name; public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public City() { } public City(Long id, String name) { super(); this.id = id; this.name = name; } /** * 根據省份id查詢省份中的城市! * * @return */ public static List<City> getCityByProvinceId(Long id) { List<City> citys = new ArrayList<City>(); if (id == 1) { citys = Arrays.asList( new City(1L,"成都"), new City(2L,"南充"), new City(3L,"綿陽"), new City(4L,"遂林"), new City(5L,"達州"), new City(6L,"德陽"), new City(7L,"樂山") ); } else if (id == 2) { citys = Arrays.asList( new City(11L,"廣州"), new City(12L,"佛山"), new City(13L,"東莞") ); } else if (id == 3) { citys = Arrays.asList( new City(21L,"昆明"), new City(22L,"玉溪"), new City(23L,"麗江") ); } return citys; } }
Province.java:
public class Province { private Long id; private String name; public Province(Long id, String name) { super(); this.id = id; this.name = name; } public Long getId() { return id; } public void setId(Long id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } public Province() { super(); } public static List<Province> getAllProvince() { List<Province> provinces = new ArrayList<Province>(); provinces.add(new Province(1L, "四川")); provinces.add(new Province(2L, "廣東")); provinces.add(new Province(3L, "云南")); return provinces; } }
提供一個CityProvinceServlet向Ajax提供請求地址:
@WebServlet("/loadData")
public class CityProvinceServlet extends HttpServlet {
@Override
protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
String cmd = req.getParameter("cmd");
String id = req.getParameter("id");
req.setCharacterEncoding("UTF-8");
resp.setContentType("text/json;charset=UTF-8");
//加載省
if(cmd.equals("province")){
List<Province> provinceList = Province.getAllProvince();
resp.getWriter().print(JSONSerializer.toJSON(provinceList));
System.out.println("加載省!");
}
//加載市
else {
if(id != null && id != ""){
List<City> cityList = City.getCityByProvinceId(Long.parseLong(id));
resp.getWriter().print(JSONSerializer.toJSON(cityList));
System.out.println("加載市!");
}
}
}
}
前臺對應使用Ajax與JSON來決議傳遞過來的JSON格式資料:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>省市二級聯動</title> <script type="text/javascript"> function getAjax(){ var ajax = null; if(XMLHttpRequest){ ajax = new XMLHttpRequest(); }else if(ActiveXObject){ ajax = new ActiveXObject("Microsoft XMLHTTP"); } return ajax; } function loadProvince() { var xhr = getAjax(); xhr.open("GET", "/loadData?cmd=province"); xhr.onreadystatechange = function () { if(xhr.readyState == 4 && xhr.status == 200){ //provinces:[{"id":1,"name":"四川"},{"id":2,"name":"廣東"},{"id":3,"name":"云南"}] var provinces = xhr.responseText; var jsonObjArr = JSON.parse(provinces); //操作DOM往省級option進行填充資料 //首先先創建每個option元素 //將jsonObj資料填充進option中 jsonObjArr.forEach( function (obj) { var option = document.createElement("option"); option.setAttribute("value", obj.id); option.innerHTML = obj.name; document.getElementById("province").appendChild(option); } ); } }; xhr.send(); } loadProvince(); function loadCity() { //得到id var id = document.getElementById("province").value; //如果是請選擇,對應就不加載 if(id == -1){ document.getElementById("city").innerHTML = "<option>----請選擇----</option>"; return; } //每次加載都初始化一次 document.getElementById("city").innerHTML = ""; var xhr = getAjax(); xhr.open("GET", "/loadData?cmd=city&id=" + id); xhr.onreadystatechange = function () { if(xhr.readyState == 4 && xhr.status == 200){ //[{"id":1,"name":"成都"},{"id":2,"name":"南充"},{"id":3,"name":"綿陽"},{"id":4,"name":"遂林"},{"id":5,"name":"達州"}, // {"id":6,"name":"德陽"},{"id":7,"name":"樂山"}] var cityes = xhr.responseText; var jsonObjArr = JSON.parse(cityes); jsonObjArr.forEach( function (obj) { var option = document.createElement("option"); option.setAttribute("value", obj.id); option.innerHTML = obj.name; document.getElementById("city").appendChild(option); } ); //去除掉----請選擇------ document.getElementById("city").options.remove(0); } }; xhr.send(); } </script> </head> <body> 省級:<select id="province" onchange="loadCity()"> <option value="-1">----請選擇----</option> </select> 市級:<select id="city"> <option>----請選擇----</option> </select> </body> </html>
實作效果如下:

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/65755.html
標籤:JavaScript
下一篇:Deno 初探
