Posted on 2008-01-10 03:05
thomas.chen 閱讀(206)
評(píng)論(0) 編輯 收藏 所屬分類:
JavaScript
1. JSON基礎(chǔ)
1.1. 定義
JSON(JavaScript Object Notation) 是一種輕量級(jí)的數(shù)據(jù)交換格式,易于閱讀和編寫,同時(shí)也易于機(jī)器解析和生成。它基于ECMA262語(yǔ)言規(guī)范(1999-12第三版)中JavaScript編程語(yǔ)言的一個(gè)子集。 JSON采用與編程語(yǔ)言無(wú)關(guān)的文本格式,但是也使用了類C語(yǔ)言(包括C, C++, C#, Java, JavaScript, Perl, Python等)的習(xí)慣,這些特性使JSON成為理想的數(shù)據(jù)交換格式。
JSON的結(jié)構(gòu)基于下面兩點(diǎn):
1. "名稱/值"對(duì)的集合 不同語(yǔ)言中,它被理解為對(duì)象(object),記錄(record),結(jié)構(gòu)(struct),字典(dictionary),哈希表(hash table),鍵列表(keyed list)等
2. 值的有序列表 多數(shù)語(yǔ)言中被理解為數(shù)組(array)
1.2. JSON使用
JSON以一種特定的字符串形式來(lái)表示 JavaScript 對(duì)象。如果將具有這樣一種形式的字符串賦給任意一個(gè) JavaScript 變量,那么該變量會(huì)變成一個(gè)對(duì)象引用,而這個(gè)對(duì)象就是字符串所構(gòu)建出來(lái)的,好像有點(diǎn)拗口,我們還是用實(shí)例來(lái)說(shuō)明。
這里假設(shè)我們需要?jiǎng)?chuàng)建一個(gè)User對(duì)象,并具有以下屬性
用戶ID
用戶名
用戶Email
您可以使用以下JSON形式來(lái)表示User對(duì)象:
{"UserID":11,
"Name":"Truly",
"Email":"zhuleipro◎hotmail.com"};
|
然后如果把這一字符串賦予一個(gè)JavaScript變量,那么就可以直接使用對(duì)象的任一屬性了。
完整代碼:
<script>
var I = {"UserID":11,
"Name":"Truly",
"Email":"zhuleipro◎hotmail.com"};
alert(User.Name);
</script>
|
實(shí)際使用時(shí)可能更復(fù)雜一點(diǎn),比如我們?yōu)?/span>Name定義更詳細(xì)的結(jié)構(gòu),使它具有FirstName和LastName:
{"UserID":11,
"Name":{"FirstName":"Truly","LastName":"Zhu"},
"Email":"zhuleipro◎hotmail.com"};
|
完整代碼:
<script>
var User = {"UserID":11,
"Name":{"FirstName":"Truly","LastName":"Zhu"},
"Email":"zhuleipro◎hotmail.com"};
alert(User.Name.FirstName);
</script>
|
現(xiàn)在我們?cè)黾右粋€(gè)新的需求,我們某個(gè)頁(yè)面需要一個(gè)用戶列表,而不僅僅是一個(gè)單一的用戶信息,那么這里就需要?jiǎng)?chuàng)建一個(gè)用戶列表數(shù)組。
下面代碼演示了使用JSON形式定義這個(gè)用戶列表:
[
{"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"}
]
|
完整代碼:
<script>
var UserList = [
{"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"}
];
alert(UserList[0].Name.firstName);
</script>
|
事實(shí)上除了使用"."引用屬性外,我們還可以使用下面語(yǔ)句:
alert(UserList[0]["Name"]["FirstName"]); 或者 alert(UserList[0].Name["FirstName"]);
歸納總結(jié):
1. 對(duì)象是屬性、值對(duì)的集合。一個(gè)對(duì)象的開(kāi)始于“{”,結(jié)束于“}”。每一個(gè)屬性名和值間用“:”提示,屬性間用“,”分隔。
2. 數(shù)組是有順序的值的集合。一個(gè)數(shù)組開(kāi)始于"[",結(jié)束于"]",值之間用","分隔。
3. 值可以是引號(hào)里的字符串、數(shù)字、true、false、null,也可以是對(duì)象或數(shù)組。這些結(jié)構(gòu)都能嵌套。
4. 字符串和數(shù)字的定義和C或Java基本一致。