<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 55,comments - 89,trackbacks - 0
    轉載: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"}

    完整代碼:

    <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 的強大用途。可以歸結如下:

  • JSON 提供了一種優秀的面向對象的方法,以便將元數據緩存到客戶機上。
  • JSON 幫助分離了驗證數據和邏輯。
  • JSON 幫助為 Web 應用程序提供了 Ajax 的本質。
  • posted on 2009-06-16 01:03 jiafang83 閱讀(331) 評論(0)  編輯  收藏

    只有注冊用戶登錄后才能發表評論。


    網站導航:
    博客園   IT新聞   Chat2DB   C++博客   博問  
     
    主站蜘蛛池模板: 国产免费一区二区三区免费视频 | 亚洲一区二区影视| 免费看少妇高潮成人片| 中文字幕亚洲专区| 久久九九免费高清视频| 亚洲色图综合在线| 一区二区视频在线免费观看| 亚洲高清偷拍一区二区三区| 色多多A级毛片免费看| 亚洲AV中文无码乱人伦| 一级毛片a免费播放王色电影| 亚洲av无码成人精品区| 免费在线观看一区| 亚洲精品亚洲人成在线观看| a级毛片在线免费观看| 久久精品国产亚洲AV无码偷窥| h视频在线免费看| 亚洲精品无码你懂的| 又粗又硬又黄又爽的免费视频| 黄色网址在线免费观看| 国产亚洲日韩在线三区| 久久免费视频网站| 亚洲AV无码久久久久网站蜜桃| 蜜桃精品免费久久久久影院| 在线观看亚洲网站| 国产亚洲人成A在线V网站| 男人进去女人爽免费视频国产| 亚洲视频在线观看免费| 成人免费毛片视频| 污视频网站在线免费看| 亚洲精品无码久久一线| 99re视频精品全部免费| 亚洲一日韩欧美中文字幕在线| 又色又污又黄无遮挡的免费视| 亚欧国产一级在线免费| 亚洲第一页中文字幕| 国产乱子伦精品免费无码专区| 国产精品偷伦视频免费观看了| 亚洲欧洲第一a在线观看| 日韩精品成人无码专区免费 | 四虎成人精品一区二区免费网站 |