一、什么是JSON?
JSON: JavaScript Object Notation(JavaScript 對象表示法)
JSON 是存儲和交換文本信息的語法。類似 XML。
JSON 比 XML 更小、更快,更易解析。
二、JSON語法規則
數據在名稱/值對中("name" : "菜鳥教程" 和 name = "菜鳥教程" 一樣)
數據由逗號分隔
大括號保存對象
中括號保存數組
JSON對象(在大括號({})中書寫)
var p ={name:"tom",age:50};
document.write(p.name);
JSON數組(在中括號中書寫)
var pp =[{name:"tom",age:50},{name:"milk",age:22}];
document.write(pp[1].name);
三、JSON中的方法
3.1、JSON.parse()方法
JSON 通常用於與服務端交換數據。在接收服務器數據時一般是字符串。我們可以使用 JSON.parse() 方法將數據轉換為 JavaScript 對象。
如:我們在服務器端有{name:"tom",age:17}
使用 JSON.parse() 方法處理以上數據,將其轉換為 JavaScript 對象
var peo = JSON.parse('{name:"tom",age:17}');
注意:解析前要確保你的數據是標准的 JSON 格式,否則會解析出錯。
在如:使用 AJAX 從服務器請求 JSON 數據,並解析為 JavaScript 對象
var xmlhttp = new XMLHttpRequest(); xmlhttp.onreadystatechange = function() { if (this.readyState == 4 && this.status == 200) { myObj = JSON.parse(this.responseText); //如果JSON數據是數據解析成對象,如果是數組,也解析成數組。 document.getElementById("demo").innerHTML = myObj.name; } }; xmlhttp.open("GET", "/try/ajax/json_demo.txt", true); xmlhttp.send();
3.2、JSON.stringify()
JSON 通常用於與服務端交換數據。在向服務器發送數據時一般是字符串。我們可以使用 JSON.stringify() 方法將 JavaScript 對象轉換為字符串。
如:我們需要將 var obj ={name:"tom",age:18};發送給服務器
JSON.stringify() 方法處理以上數據,將其轉換為字符串:
JSON.stringify(obj);
再如:將javascript數組轉換成JSON字符串
var arr = [ "Google", "Runoob", "Taobao", "Facebook" ];
var myJSON = JSON.stringify(arr);
document.getElementById("demo").innerHTML = myJSON;
四、使用JSON框架
使用框架必然要導入的是jar包,最后可以為大家提供jar包,接下來我們看它的用法。
package testJSON; import java.sql.SQLException; import java.util.ArrayList; import java.util.List; import net.sf.json.JSONArray; import net.sf.json.JSONObject; import net.sf.json.JsonConfig; import org.apache.commons.dbutils.QueryRunner; import org.apache.commons.dbutils.handlers.BeanListHandler; import org.junit.Test; import com.jxlg.domain.Book; import com.jxlg.util.C3P0Util; public class testJSON { @Test //使用JSONObject對象封裝對象數據類型 public void test() { Book b = new Book(); b.setName("賬單"); b.setId("100"); b.setPrice(55); String s = JSONObject.fromObject(b).toString(); System.out.println(s); } @Test //使用JSON對象封裝List<Book> public void test1(){ List<Book> books = new ArrayList<Book>(); Book b1 =new Book(); Book b2 =new Book(); Book b3 =new Book(); b1.setName("賬單"); b1.setId("1001"); b1.setPrice(55); b2.setName("花花"); b2.setId("1002"); b2.setPrice(23); b3.setName("阿德"); b3.setId("1003"); b3.setPrice(11); books.add(b1); books.add(b2); books.add(b3); String m = JSONArray.fromObject(books).toString(); System.out.println(m); } @Test //使用JsonConfig去除不需要的字段 public void test3() throws SQLException{ QueryRunner qr =new QueryRunner(C3P0Util.getDateSource()); List<Book> books = qr.query("select * from book", new BeanListHandler<Book>(Book.class)); JsonConfig jc = new JsonConfig(); jc.setExcludes(new String[]{"id","category","description"}); String m = JSONArray.fromObject(books,jc).toString(); System.out.println(m); } }
結果:
把這些數據都封裝成了JSON類型的數據,可以在前端更好的獲取顯示
提供使用JSON中需要的jar包,不謝:
鏈接:http://pan.baidu.com/s/1pKBwSOV 密碼:iru5
20:08:44