來源:
http://www.cnblogs.com/truly/archive/2006/12/31/608896.html
json定義
json(javascript object notation) 是一種輕量級的資料交換格式,易于閱讀和編寫,同時也易于機器解析和生成。它基于ecma262語言規範(1999-12第三版)中javascript程式設計語言的一個子集。 json采用與程式設計語言無關的文本格式,但是也使用了類c語言(包括c, c++, c#, java, javascript, perl, python等)的習慣,這些特性使json成為理想的資料交換格式。
json的結構基于下面兩點
1. "名稱/值"對的集合 不同語言中,它被了解為對象(object),記錄(record),結構(struct),字典(dictionary),哈希表(hash table),鍵清單(keyed list)等
2. 值的有序清單 多數語言中被了解為數組(array)
json使用:
json以一種特定的字元串形式來表示 javascript 對象。如果将具有這樣一種形式的字元串賦給任意一個 javascript 變量,那麼該變量會變成一個對象引用,而這個對象就是字元串所建構出來的,好像有點拗口,我們還是用執行個體來說明。
這裡假設我們需要建立一個user對象,并具有以下屬性
使用者id
使用者名
使用者email
您可以使用以下json形式來表示user對象:
{"userid":11, "name":"truly", "email":"zhuleipro◎hotmail.com"};
然後如果把這一字元串賦予一個javascript變量,那麼就可以直接使用對象的任一屬性了。
完整代碼:
<script>
var user = {"userid":11, "name":"truly", "email":"zhuleipro◎hotmail.com"};
alert(user.name);
</script>
實際使用時可能更複雜一點,比如我們為name定義更詳細的結構,使它具有firstname和lastname:
{"userid":11, "name":{"firstname":"truly","lastname":"zhu"}, "email":"zhuleipro◎hotmail.com"}
var user = {"userid":11, "name":{"firstname":"truly","lastname":"zhu"}, "email":"zhuleipro◎hotmail.com"};
alert(user.name.firstname);
現在我們增加一個新的需求,我們某個頁面需要一個使用者清單,而不僅僅是一個單一的使用者資訊,那麼這裡就需要建立一個使用者清單數組。
下面代碼示範了使用json形式定義這個使用者清單:
[
{"userid":11, "name":{"firstname":"truly","lastname":"zhu"}, "email":"zhuleipro◎hotmail.com"},
{"userid":12, "name":{"firstname":"jeffrey","lastname":"richter"}, "email":"xxx◎xxx.com"},
{"userid":13, "name":{"firstname":"scott","lastname":"gu"}, "email":"xxx2◎xxx2.com"}
]
var userlist = [
];
alert(userlist[0].name.firstname);
事實上除了使用"."引用屬性外,我們還可以使用下面語句:
alert(userlist[0]["name"]["firstname"]); 或者 alert(userlist[0].name["firstname"]);
現在讀者應該對json的使用有點認識了,歸納為以下幾點:
對象是屬性、值對的集合。一個對象的開始于“{”,結束于“}”。每一個屬性名和值間用“:”提示,屬性間用“,”分隔。
數組是有順序的值的集合。一個數組開始于"[",結束于"]",值之間用","分隔。
值可以是引号裡的字元串、數字、true、false、null,也可以是對象或數組。這些結構都能嵌套。
字元串和數字的定義和c或java基本一緻。
小節:
本文通過一個執行個體示範,初步了解了json 的強大用途。可以歸結如下:
json 提供了一種優秀的面向對象的方法,以便将中繼資料緩存到客戶機上。
json 幫助分離了驗證資料和邏輯。
json 幫助為 web 應用程式提供了 ajax 的本質。
參考資料:
http://www.json.org/