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

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

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

    經驗不在于年限,在于積累---專注互聯網軟件開發

    把工作當事業做,把項目當作品做!

      BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
      55 Posts :: 0 Stories :: 66 Comments :: 0 Trackbacks
     

    JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式,采用完全獨立于語言的文本格式,是理想的數據交換格式。同時,JSON JavaScript 原生格式,這意味著在 JavaScript 中處理 JSON數據不需要任何特殊的 API 或工具包。
    本文主要是對JS操作JSON的方法做下總結。

    在JSON中,有兩種結構:對象和數組。
        1. 一個對象以“{”(左括號)開始,“}”(右括號)結束。每個“名稱”后跟一個“:”(冒號);“‘名稱/值’ 對”之間使用“,”(逗號)分隔。 名稱用引號括起來;值如果是字符串則必須用括號,數值型則不需要。例如:
        var o={"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"};    
        2. 數組是值(value)的有序集合。一個數組以“[”(左中括號)開始,“]”(右中括號)結束。值之間使用“,”(逗號)分隔。
        例如:
        var jsonranklist=[{"xlid":"cxh","xldigitid":123456,"topscore":2000,"topplaytime":"2009-08-20"},{"xlid":"zd","xldigitid":123456,"topscore":1500,"topplaytime":"2009-11-20"}];

    為了方便地處理JSON數據,JSON提供了json.js包,下載地址:http://www.json.org/json.js

    在數據傳輸過程中,json是以文本,即字符串的形式傳遞的,而JS操作的是JSON對象,所以,JSON對象和JSON字符串之間的相互轉換是關鍵。例如:
           JSON
    字符串:
           var str1 = '{ "name": "cxh", "sex": "man" }'; 
           JSON對象:
           var str2 = { "name": "cxh", "sex": "man" }; 


    一、
    JSON字符串轉換為JSON對象

    要使用上面的str1,必須使用下面的方法先轉化為JSON對象:

    //JSON字符串轉換為JSON對象

    var obj = eval('(' + str + ')');

    或者

    var obj = str.parseJSON(); //JSON字符串轉換為JSON對象 

    或者

    var obj = JSON.parse(str); //JSON字符串轉換為JSON對象

    然后,就可以這樣讀取:

    Alert(obj.name);

    Alert(obj.sex);

     

    特別注意:如果obj本來就是一個JSON對象,那么使用eval()函數轉換后(哪怕是多次轉換)還是JSON對象,但是使用parseJSON()函數處理后會有問題(拋出語法異常)。



    二、可以使用
    toJSONString()或者全局方法JSON.stringify()JSON對象轉化為JSON字符串。

    例如:

    var last=obj.toJSONString(); //JSON對象轉化為JSON字符

    或者

    var last=JSON.stringify(obj); //JSON對象轉化為JSON字符

    alert(last);


    注意:
        上面的幾個方法中,除了
    eval()函數是js自帶的之外,其他的幾個方法都來自json.js包。新版本的 JSON 修改了 API,將 JSON.stringify() JSON.parse() 兩個方法都注入到了 Javascript 的內建對象里面,前者變成了 Object.toJSONString(),而后者變成了 String.parseJSON()。如果提示找不到toJSONString()parseJSON()方法,則說明您的json包版本太低。

    友情提醒:本博文章歡迎轉載,但請注明出處:陳新漢

    posted on 2009-09-15 21:58 hankchen 閱讀(40724) 評論(14)  編輯  收藏 所屬分類: JS+jQuery

    Feedback

    # re: JS操作JSON總結 2009-09-16 19:40 cxh8318
    不錯!!!!!!  回復  更多評論
      

    # re: JS操作JSON總結 2009-09-18 02:37 learngogo
    謝謝  回復  更多評論
      

    # re: JS操作JSON總結 2010-08-08 19:48 心夢帆影
    總結的不錯,一直沒搞清,要用哪些轉換的方法,有哪些兼容問題。
    看了你的文章,突然有點明白了。

    --看到你博客上的“經驗不在于年限,在于積累”,覺得很有道理。  回復  更多評論
      

    # re: JS操作JSON總結 2010-12-06 10:16 huqq
    很不錯的資料  回復  更多評論
      

    # re: JS操作JSON總結[未登錄] 2011-03-02 14:02 小弟
    講解的非常不錯!簽名都是那么的有個性,講解的更是。讓我徘徊幾個月。今天算是知道怎么回事了。謝謝!  回復  更多評論
      

    # re: JS操作JSON總結 2011-03-25 21:24 shuang
    我把你的博客放到我的收藏夾里面了..以后關注  回復  更多評論
      

    # re: JS操作JSON總結 2011-08-09 13:33 31互聯
    www.31idc.com  回復  更多評論
      

    # re: JS操作JSON總結 2011-10-13 11:38 like
    謝謝 很有用  回復  更多評論
      

    # re: JS操作JSON總結 2011-11-25 09:56 深入.net
    @心夢帆影
    大實話  回復  更多評論
      

    # re: JS操作JSON總結 2012-01-05 14:56 大袋鼠
    好!  回復  更多評論
      

    # re: JS操作JSON總結 2012-03-08 16:42 小莫莫
    好東西啊  回復  更多評論
      

    # re: JS操作JSON總結 2013-05-18 12:02 Romen
    感謝分享  回復  更多評論
      

    # re: JS操作JSON總結 2013-12-31 13:35 比特
    不錯  回復  更多評論
      

    # re: JS操作JSON總結 2014-11-21 17:22 菜鳥程序員
    寫的真不錯  回復  更多評論
      

    主站蜘蛛池模板: 亚洲av福利无码无一区二区 | 亚洲aⅴ无码专区在线观看| 免费国产成人午夜在线观看| 91亚洲精品麻豆| 亚洲av无码片区一区二区三区| 久久免费精彩视频| 免费观看大片毛片| 亚洲AV男人的天堂在线观看| 国产成人精品免费视频大全| 四虎在线最新永久免费| 四虎永久免费地址在线网站 | 久久久青草青青亚洲国产免观| 亚洲天堂一区在线| xxxxx做受大片在线观看免费 | 亚洲嫩草影院久久精品| 欧洲精品99毛片免费高清观看| 免费大香伊蕉在人线国产| 日本中文一区二区三区亚洲| 亚洲人成图片小说网站| 亚洲欧美成人综合久久久| 免费视频精品一区二区三区| 亚洲人成网www| 无码国产精品一区二区免费I6| 亚洲爆乳无码精品AAA片蜜桃| 精品无码无人网站免费视频| 亚洲日韩国产一区二区三区| 中国在线观看免费的www| 亚洲日本一区二区三区| 国产免费看JIZZ视频| 免费看又黄又爽又猛的视频软件| 亚洲色婷婷六月亚洲婷婷6月| 久久不见久久见免费视频7 | 亚洲综合色7777情网站777| 免费国产成人午夜在线观看| 亚洲一区二区三区播放在线| 亚洲AV无码之日韩精品| 亚洲av无码专区国产不乱码| 久久久久亚洲精品天堂久久久久久| 91香蕉在线观看免费高清| 亚洲国产精品无码久久| 亚洲国产AV无码专区亚洲AV|