初學者看過來之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
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...