JavaScript 關於JSON的訪問

來源:互聯網
上載者:User

JSON的結構基於下面兩點
1. "名稱/值"對的集合 不同語言中,它被理解為對象(object),記錄(record),結構(struct),字典(dictionary),雜湊表(hash table),鍵列表(keyed list)等
2. 值的有序列表 多數語言中被理解為數組(array)

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"}

完整代碼:
<script>
var User = {"UserID":11, "Name":{"FirstName":"Truly","LastName":"Zhu"}, "Email":"zhuleipro◎hotmail.com"}; alert(User.Name.FirstName); </script>

現在我們增加一個新的需求,我們某個頁面需要一個使用者列表,而不僅僅是一個單一的使用者資訊,那麼這裡就需要建立一個使用者列表數組。
下面代碼示範了使用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"}
]

完整代碼:
<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>

事實上除了使用"."引用屬性外,我們還可以使用下面語句:
alert(UserList[0]["Name"]["FirstName"]); 或者 alert(UserList[0].Name["FirstName"]);

現在讀者應該對JSON的使用有點認識了,歸納為以下幾點:
對象是屬性、值對的集合。一個對象的開始於“{”,結束於“}”。每一個屬性名稱和值間用“:”提示,屬性間用“,”分隔。
數組是有順序的值的集合。一個數組開始於"[",結束於"]",值之間用","分隔。
值可以是引號裡的字串、數字、true、false、null,也可以是對象或數組。這些結構都能嵌套。
字串和數位定義和C或Java基本一致。

基本訪問 :

第一種有主條目的JSON

var data = { root: [{ name: "張三", value: "北京市" },
{ name: "李四", value: "天津市" },
{ name: "馬五", value: "洛陽" },
{ name: "王六", value: "西安"}],
layer1: [{ name: "zhangsan", value: "北京市" },
{ name: "lisi", value: "天津市" },
{ name: "mawu", value: "洛陽" },
{ name: "wangliu", value: "西安"}]
};

alert(data.root.length);
for (var i = 0; i < data.root.length; i++) {
alert("name:" + data.root[i].name);
alert("value:" + data.root[i].value);
}
alert(data.layer1.length);
for (var i = 0; i < data.layer1.length; i++) {
alert("name:" + data.layer1[i].name);
alert("value:" + data.layer1[i].value);
}

第二種 數組裡面嵌套對象

var data2 = [
{ name: "山東省", citys: { city: ["濟南", "青島"]} },
{ name: "河北省", citys: { city: ["保定", "石家莊", "衡水"]} },
{ name: "山西省", citys: { city: ["太原", "大同"]} }
];
alert(data2.length);
for (var i = 0; i < data2.length; i++) {
alert(data2[i].name);
for (var j = 0; j < data2[i].citys.city.length; j++) {
alert(data2[i].citys.city[j]);
}
}

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.