JSON數據理解

来源:http://www.cnblogs.com/fifalover09/archive/2016/01/13/5127921.html
-Advertisement-
Play Games

話說JSON數據平常用的確實挺多的,但是基本上只知道怎麼用,對其一些細節並沒有整理過,今兒趁著下午有點空,坐下來,學習整理下,並分享出來。 對於JSON,首先它只是一種數據格式,並非一種語言,雖然和javascript長的比較像,但並不從屬於javascript。如果你使用過其他編程...


      話說JSON數據平常用的確實挺多的,但是基本上只知道怎麼用,對其一些細節並沒有整理過,今兒趁著下午有點空,坐下來,學習整理下,並分享出來。

       

      對於JSON,首先它只是一種數據格式,並非一種語言,雖然和javascript長的比較像,但並不從屬於javascript。如果你使用過其他編程語言,就會知道,其他語言也有針對JSON的解析器和序列化器。

      JSON可以表示以下3中類型的值

  •       簡單值    如字元串、數值、布爾值和null,但不支持undefined
  •       對象       對象作為一種複雜的數據類型,表示是一組無序的鍵值對兒,值可以是簡單值也可以複雜的數據
  •       數組       數組作為一種複雜的數據類型,表示是一組有序的列表兒,可以通過索引來獲取引用的值,值可以是簡單值,也可以複雜數據對象

 

    1 . 簡單值

    簡單值里沒有什麼可以重點講的,主要強調一點,而且非常重要,那就是 JSON 字元串必須使用雙引號,單引號會報錯

    2. 對象

     javascript 中的對象

     

var object = {

                  name:"suyq",

                  age :9

       }

 

   JSON 對象

   

{ 
    "name":"suyq",
    "age" :9
}

 

與javascript對象相比,JSON對象有兩個地方不一樣

  1. 沒有聲明變數(JSON中沒有變數的概念)
  2. 末尾沒有分號  

再說一遍 對象的屬性必須加雙引號,這個是必須的。

屬性的值可以是簡單類型,也可以是複雜類型的值。

 

{ 
    "name":"suyq",
    "age" :9,
     "school":{
                      "name":"tjn",
                       "location":"tj"
                    }
}

 

 

 

    3.數組

    javascript中的數組字面量

    

var  v = [1,"hi",true];

  JSON中的數組

[
            {
                "name": "張三",
                "age": 18
            },
            {
                "name": "李四",
                "age": 22
            },
            {
                "name": "王五",
                "age": 20
            }
        ]

  JSON對象

      json 對象主要有兩個方法 

      JSON.stringify();

      把javascript 對象轉換為json對象

      

 var book =
   {
       title:"javascript",
       authors:["li","susan"],
       year:2011,
edition:undefined
}; console.log(JSON.stringify(book));

 

     輸出結果:

     {"title":"javascript","authors":["li","susan"],"year":2011}

    預設情況下,javascript.stringify()所輸出的json 字元串不包含任何空格字元和縮進。

   值為undefined的任何屬性會被跳過。

     

    序列號選項

     javascript.stringify() 函數還可以接收兩個參數,第一個參數是個過濾器,可以是個數組,也可以是個函數,第二個是字元串中保留縮進。

     1.過濾器

      

var book =
   {
       title:"javascript",
       authors:["li","susan"],
       year:2011,
       edition:undefined
   };
    console.log(JSON.stringify(book,["title"]));

 

      輸出結果:{"title":"javascript"}

      如果第二個參數是函數,傳入的函數有兩個參數,屬性鍵名和鍵值。話不多說,直接上例子。

      

 var book =
   {
       title:"javascript",
       authors:["li","susan"],
       year:2011,
       edition:undefined
   };
    console.log(JSON.stringify(book,function(key,value){

          switch (key)
          {
              case "authors":
                      return value.join(",");
              case "edition":
                      return undefined;
              default :
                      return value;
          }
    }));

 

      輸出結果:{"title":"javascript","authors":"li,susan","year":2011}

      2.字元串縮進

       

var book =
   {
       title:"javascript",
       authors:["li","susan"],
       year:2011,
       edition:undefined
   };
    console.log(JSON.stringify(book,function(key,value){

          switch (key)
          {
              case "authors":
                      return value.join(",");
              case "edition":
                      return undefined;
              default :
                      return value;
          }
    },5));

 

      輸出結果:

      

{
     "title": "javascript",
     "authors": "li,susan",
     "year": 2011
}

 

     註意:最大縮進空格數為10 ,大於10 自動轉換為10縮進。

     2.toJSON 方法

      

 var book =
   {
       title:"javascript",
       authors:["li","susan"],
       year:2011,
       edition:undefined,
       toJSON :function()
           {
               return this.title;
           }
   };

 

 

     輸出結果:"javascript"

      有時候如果JSON.stringify()還無法滿足序列化需求,可以通過對象上調用toJSON()方法,返回其自身的JSON數據格式。

      toJSON()函數可以作為過濾器的補充。

      把一個對象傳入JSON.stringify(),序列化順序如下

      1.如果存在toJSON()方法,而且通過它可以取到有效值,則先調用它。否則,按照預設順序執行序列化

      2.如果提供第二個參數,執行該過濾器,傳入過濾器的值是第一步的返回值

      3.對第二步返回的值進行相應的序列化

      4.如果提供了第三個參數,執行的相應的格式化

 

     

      JSON.parse();

       json.parse() 也可以接收另一個參數,該參數也是一個函數。

       

 var book =
   {
       title:"javascript",
       authors:["li","susan"],
       year:2011,
       edition:undefined,
       releaseDate:new Date(2011,1,1)

   };
   var jsonText  = JSON.stringify(book);
   var bookcopy = JSON.parse(jsonText,function(key,value){
          if(key=="releaseDate")
          {
              return new Date();
          }else
          {
              return value;
          }
     })
    console.log(bookcopy.releaseDate.getFullYear());

 

      輸出結果:2016 


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

-Advertisement-
Play Games
更多相關文章
  • 前言:方法替換,可以替換任意外部類的方法,而動態添加方法只能實現在被添加類創建的對象里,但是將方法替換和動態添加方法結合使用,可以實現,對任意外部類動態添加需要的方法,這個方法可以是類方法也可以是實例方法,這個外部類也可以是沒有任何方法聲明和實現的類。主要思路:使用運行時的方法替換將在外部類將自定義...
  • 線程通信、ActivityThread及Thread類是理解Android線程管理的關鍵。 線程,作為CPU調度資源的基本單位,在Android等針對嵌入式設備的操作系統中,有著非常重要和基礎的作用。本小節主要從以下三個方面進行分析: 《Android線程管理——線程通信》 《Android線程管理...
  • 下麵通過一個實例展示一下Runtime(動態添加屬性)的用法
  • 一,效果圖。二,代碼。//點擊任何處,彈出提示選項-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event{ UIAlertView * alert=[[UIAlertView alloc] initWithTitl...
  • 本文總結了20種ios濾鏡都是基於GPUImage的,有3種濾鏡是GPUImage庫中包含的,還有17種是Instagram中的經典濾鏡,集成在一個項目中。使用GPUImage可以非常容易創建我們自己的濾鏡效果總會有你想要的效果吧。在文章下麵附源碼下載 相信你也在使用濾鏡吧,今天就讓你見識一下...
  • 雜談在進行android進行開發時,我們的數據一般通過介面來獲收,這裡指的介面泛指web api,webservice,wcf,web應用程式等;它們做為服務端與資料庫進行直接通訊,而APP這塊通過向這些介面發Http請求來獲得數據,這樣的好處大叔認為,可以有效的降低軟體的開發難度,所以數據交互都被...
  • JavaScript數組常用操作、總結
  • jQuery
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...