1. 程式人生 > >js解析與序列化json數據

js解析與序列化json數據

color AS 簡單 字符 IT tro 需要 strong init

一、前言:JSON對象有兩個方法:stringify()和parse()。

二、介紹:在最簡單的情況下,這兩個方法分別用於把JavaScript對象序列化為JSON字符串和把JSON字符串解析為原生JavaScript。

1、瀏覽器支持的轉換方式(Firefox,chrome,opera,safari,ie9,ie8)等瀏覽器:

  JSON.stringify(jsonobj); //將json對象轉換成json字符串

  JSON.parse(jsonstr); //將json字符串轉換成json對象

2、另外還有eval() 函數可計算某個字符串,並執行其中的的 JavaScript 代碼:


  eval(‘(‘+jsonstr+‘)‘); //將json字符串轉換成json對象,註意需要在json字符串外包裹一對小括號

  提示:雖然 eval() 的功能非常強大,但在實際使用中用到它的情況並不多。

三、事例:

function init() {

  var book={
    title:"JavaScript高級程序設計",
    authors:[
      "Nicholas C. Zakas"
    ],
    edition:3,
    year:2011
  };
  var jsonBook=JSON.stringify(book);
  var objectBook=JSON.parse(jsonBook);

}

三、詳解:

1、默認情況下,JSON.stringify()輸出的JSON字符串不包含任何空字符或縮進,因此保存在jsonBook中的字符串如下所示:

  {"title":"JavaScript高級程序設計","authors":["Nicholas C. Zakas"],"edition":3,"year":2011}

2、在序列化JavaScript對象時,所有函數及原型成員都會被有意忽略,不體現在結果中。此外,值為undefined的任何屬性也都會被跳過。結果中最終都是值為有效JSON數據類型的實例屬性。

3、註意,雖然book與objectBook1具有相同的屬性,但它們是兩個獨立的、沒有任何關系的對象。如果傳給JSON.parse()的字符串不是有效的JSON,該方法會拋出錯誤。

js解析與序列化json數據