初學者看過來之JSON入門

来源:http://www.cnblogs.com/zhouhuan/archive/2016/12/22/json.html
-Advertisement-
Play Games

1. 什麼是JSON JSON Javascript Object Notation,前兩個單詞大家應該都認識,最後一個notation,是“記號、標記法”的意思,連在一起,便成了JSON。 它是一種輕量級的數據交換格式,是基於Javascript的一個子集,可以叫做Javascript對象表示法, ...


1. 什麼是JSON JSON---Javascript Object Notation,前兩個單詞大家應該都認識,最後一個notation,是“記號、標記法”的意思,連在一起,便成了JSON。 它是一種輕量級的數據交換格式,是基於Javascript的一個子集,可以叫做Javascript對象表示法,是存儲和交換文本信息的語法,但它並不是Javascript獨有的數據格式,其它很多語言都可以對JSON進行解析和序列化。 2. JSON的由來 在21世紀初,Douglas Crockford(Web開發領域最知名的技術權威之一,ECMA JavaScript2.0標準化委員會委員,被JavaScript之父Brendan Eich稱為JavaScript的大宗師(Yoda),曾任Yahoo!資深JavaScript架構師,現任PayPal高級JavaScript架構師)試圖尋找一種更加簡便的數據交換格式,能夠在伺服器之間交換數據,當時通用的數據交換語言是XML,但是Douglas Crockford認為XML的生成與解析都過於麻煩,所以他提出了一種更加簡化的格式,就是我們現在使用的JSON。 JSON的規格十分簡單,只用一個頁面幾百個字就能說清楚,而且Douglas Crackford稱這個規格永遠不用升級,因為該規定的都已經規定好了。 3. 為什麼要用JSON JSON類似於XML,比XML更小、更快、更容易解析。但同時XML也有它的不可替代性,應根據使用場景進行更合適的選擇; JSON語法簡單,很容易理解,並且對象信息自描述,數據傳輸量小不占用帶寬; JSON雖然遠不及emoji這一世界通用語言,但其實它的支持度也已經非常可觀,支持的語言包括C,C#,Java,JavaScript,PHP,Python,Ruby等等; 對於Ajax應用程式來說,JSON比XML更快捷,更易用; JSON的可讀性、可擴展性都非常好,編碼難度也比較低,即使不藉助工具也能寫出比較規範的JSON ...... 4. JSON怎麼用 ⑴ JSON的基本語法 ① 併列的數據之間用逗號( , )分隔 ② 映射用冒號( : )表示 ③ 映射的集合用大括弧( {} )表示 ④ 併列數據的集合用方括弧( [] )表示 例如: 上賽季的MVP是斯蒂芬庫里,場上位置是控球後衛,球衣號碼是30號,球隊是金州勇士隊 上賽季的FMVP是勒布朗詹姆斯,場上位置是小前鋒,球衣號碼是23號,球隊是克裡夫蘭騎士隊 用JSON格式就可以表示為:
[{
        "MVP":"Stephen Curry",
        "position":"Point Guard",
        "number":"30",
        "team":"Golden State Warriors"
    },{
        "FMVP":"Lebron James",
        "position":"Small Forward",
        "number":"23",
        "team":"Cleveland Cavaliers"
    }]    

  更複雜的數據也可以使用JSON來進行表示,比如下麵這段信息:最喜歡的編輯器是sublime,最喜歡的運動是籃球,最喜歡的球隊是馬刺隊,馬刺隊控衛有托尼帕克、帕蒂米爾斯,分衛有馬努吉諾比利、丹尼格林,小前鋒有科懷倫納德、凱爾安德森,大前鋒有拉馬庫斯阿爾德里奇、大衛李,中鋒有德維恩戴德蒙、保羅加索爾。  

{
        "favoriteEditor": "sublime",
        "favoriteSport": "basketball",
        "favoriteTeam":{
            "Spurs":[
                {
                    "PG":"Tony Parker",
                    "SG":"Danny Green",
                    "SF":"Kawhi Leonard",
                    "PF":"LaMarcus Aldridge",
                    "C":"Pau Gasol"    
                },
                {
                    "PG":"Patty Mills",
                    "SG":"Manu Ginobili",
                    "SF":"Kyle Anderson",
                    "PF":"David Lee",
                    "C":"Dewayne Dedmon"    
                }
            ]
        }
    }
⑵ JSON的解析與序列化 ① 通過eval()函數將JSON字元串解析為JavaScript原生值
var str = '[{"name":"james","height":"203","number":"23"},    {"name":"kobe","height":"198","number":"24"}]';             //定義JSON字元串
    var oJson = eval(str);            //通過eval()函數解析拿到JavaScript原生值
    //接下來便可通過JS進行操作
    alert(oJson[0].name);            //james
    alert(oJson[1].height);        //198
② 通過全局對象JSON的兩個方法parse()和stringify()進行操作 parse()可以將JSON字元串轉化為JavaScript原生值:
var str = '[{"name":"james","height":"203","number":"23"},{"name":"kobe","height":"198","number":"24"}]';                     //定義JSON字元串
    var oJson = JSON.parse(str);        //通過JSON對象的parse方法得到該JSON字元串的JavaScript原生值
    document.write("姓名:" + oJson[1].name + "<br/>" + "身高:" + oJson[1].height + "cm" + "<br/>" + "球衣號碼:" + oJson[1].number);

parse()也可以傳第二個參數,此時可以在還原出JavaScript值的時候將原值替換成自己想要的值,如下:
var str = '[{"name":"james","height":"203","number":"23"},{"name":"kobe","height":"198","number":"24"}]';
    var oJson = JSON.parse(str, function(key, value){
        if('name' == key){
            return '球員' + value;
        }else if('number' == key){
            return value + '號球衣';
        }else{
            return value;
        }
    });
    alert(oJson[0].name + '更牛逼還是' + oJson[1].name + '更牛逼' + '\n' + '你喜歡' + oJson[0].number + '還是' + oJson[1].number);

stringify()可以將原生JavaScript值轉換為JSON字元串:
var oJson = [{
        name : "james",
        height : 203,
        number : 23
    },{
        name : "kobe",
        height : 198,
        number : 24
    }];
    var jsonStr = JSON.stringify(oJson,['name','number'],4);
    alert(jsonStr);

JSON.stringify(oJson,['name','number'],4);中的第一個參數表示需要轉化的JS對象;第二個參數用於過濾結果,表示只留下name和number,其他的key以及所對應的的value都不要了;第三個參數表示在JSON字元串中保留的縮進數,有縮進時可讀性更高,該參數也可以是一個字元串,比如'----',此時彈出結果如下: 如果不需要保留縮進,那麼最後一個參數空起來即可,但如果不需要進行過濾,第二個參數需設置為null占位,不能空起來,否則最後一個參數也會失效。 第二個參數也可以是函數,函數可以進行更加複雜的過濾:
var oJson = [{
        name : "james",
        height : 203,
        position : '小前鋒'
    },{
        name : "kobe",
        height : 198,
        position : '得分後衛'
    }];
    var jsonStr = JSON.stringify(oJson,function(key,value){
        switch(key){
            case 'name':
                return '球員 ' + value;
            case 'height':
                return '身高 ' + value + 'cm';
            case 'position':
                    return '位置 ' + value;
            default:
                return value;
        }
    },4);
    alert(jsonStr);

   支持JSON對象的瀏覽器有IE8+、Chrome、FireFox3.5+、Opera10.5+、Safari4+,不支持的瀏覽器可以通過json.js這一開源庫來進行模擬。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 項目中碰到一個十分有趣的情形: 佈局要求是這樣:右邊創建新訂單是固定寬度80px,左側是自適應寬度,溢出隱藏。如下圖。 這裡佈局不用說肯定使用display:flex的。左側flex:1;右側width:80px;。 本來在我的機器上是各種ok的,可是交給後端的兄弟們後發現在他的機器上左側並沒有fl ...
  • 點擊按鈕彈出上傳文件的視窗 1.詳細描述 在頁面上設置一個“選擇文件”按鈕,點擊該按鈕,會彈出本地磁碟信息用於選擇文件。 2.代碼 3.操作示例 將代碼複製到W3CSchool的測試頁面,提交運行之後如圖:在查看結果頁面會出現“選擇文件”這個按鈕 之後點擊“選擇文件”後如圖:頁面上會出現彈窗,顯示本 ...
  • 因關註公眾號《HTML5學堂》看到這篇文章 “利用本地存儲,記錄滾動條的位置” ,便好奇敲來試試,然後又看了一些關於WebStorage的資料 附上這篇文章的地址 https://mp.weixin.qq.com/s/z34GRUZvDU2hCbH6Kc_ZDA 與大家共勉。 在網上搜了一些記錄滾動 ...
  • [1]概述 [2]段落 [3]換行 [4]標題 [5]區塊 [6]列表 [7]分隔線 [8]鏈接 [9]圖片 [10]代碼 [11]強調 [12]空兩格 ...
  • 正則表達式 1.概念 正則表達式是一種含有某種規則的模式,被用來檢索、替換符合給定模式的文本。 全稱為 Regular Expression,在 JavaScript 中簡寫為 RegExp。 2.字元 常用的元字元如下: \ 轉義符,例如匹配符號"*",則要寫成"\*"。因為有些特殊字元是元字元, ...
  • 說起flexbox,都算是件陳年舊事了,它是2009年W3C提出的一種全新的可伸縮的CSS佈局方式。依賴flexbox,我們可以更簡單,高效的完成可伸縮式頁面的佈局。 業界與flexbox的相關教程文章也是各式各樣,新舊交替,很多小伙伴對flexbox想用又不敢用,究其原因也就是即分不清它各個版本的 ...
  • 如果是p的width:100%,則說明p的width會得到980px就已經充滿div區域,然後自己又有padding,所以會超出div。 而當width:auto時它是總體寬度(包括width,margin,padding,border)等於父級寬度(width,不包含父級的margin,paddi ...
  • 首次來博客園發帖,從本地部署arcgis api開始吧; 首先還是下載arcgis的api包開始,在中國區官網下載arcgis包: 1.http://support.esrichina.com.cn/2011/0223/960.html 2.library是我們要部署的api包,sdk是一些很好的學 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...