溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

詳解JavaScript中js對象與JSON格式字符串的相互轉換

發布時間:2020-09-04 11:11:48 來源:腳本之家 閱讀:189 作者:吃貓的大魚 欄目:web開發

首先我們來看一下js中JSON格式的字符串

var JSONStr1 = "{\"name\" : \"張三\"}";

注意以下的寫法不是js中JSON格式的字符串,它只是一個js的字符串。

var JSONStr2 = "{'name' : '張三'}";

我們看JSON語法中對于字符串的定義:是由雙引號包圍的任意數量Unicode字符的集合,使用反斜線轉義。一個字符(character)即一個單獨的字符串(character string)。

下面我們來看一下在js中怎么把JSON格式的字符串轉換成一個JS對象。(

var jsObj3 = eval("(" + JSONStr1 + ")");
var jsObj4 = JSON.parse(JSONStr1);

推薦使用第二種方式具體原因請參看:http://www.json.org.cn/resource/json-in-javascript.htm

此外提一句使用這兩種方式轉換后的js對象,應該是“一個符合JSON數據格式的js對象”,也就是說它的屬性是帶著引號的,這只是我的一種猜測,因為如果JSON格式的字符串如下表示:

var JSONStr1 = "{\"f[name]\" : \"張三\"}";

那么轉換后的JS對象的屬性必定要加上引號,因為js對象的屬性不加引號只能使用字母,數字,下劃線和$符號表示,使用其它符號屬性就要加上引號了,所以說JS對象字面量表示法中屬性加上引號是不會錯的。另外如果JSON格式的字符串如上所示,那么轉換后的js對象對f[name]取值就不能使用 jsObj4.f[name] 要用 jsObj4['f[name]'] ,因為有特殊字符,這點要注意了。對于我的猜測,讀者要有異議,可以提給我。

我們再來看看在js中js對象與JSON格式字符串的轉換。下面我準備了幾組js對象加以說明:

<input type="button" value="測試按鈕1" onclick="testJson();"/>

<script type="text/javascript">
  //(1) 這是一個js對象
  var jsObj1 = {
    name : "張三"
  }
  //(2)這是一個內部帶有方法js對象。
  var jsObj2 = {
    name : "張三",
    func : function(){
      alert("hello");
    }
  }
  //(3)這是一個符合JSON數據格式的js對象
  var jsonObj = {
    "name" : "張三",
    "age" : 10,
    "remark" : {"high" :170,"address" : "beijingshi"}
  }
  // js數組對象
  var jsArray = [
    {name : "張三"},
    {"age" : 10}
  ]

  function testJson(){

    var JSONstr1 = JSON.stringify(jsObj1);
    var JSONstr2 = JSON.stringify(jsObj2);
    var JSONstr3 = JSON.stringify(jsonObj);
    var JSONstr4 = JSON.stringify(jsArray);
    alert(JSONstr1);
    alert(JSONstr2);
    alert(JSONstr3);
    alert(JSONstr4);

  }

看一下彈框的內容:

               (1)                                              (2)                                      

詳解JavaScript中js對象與JSON格式字符串的相互轉換                  詳解JavaScript中js對象與JSON格式字符串的相互轉換

                      (3)                                                                      ?。?)

詳解JavaScript中js對象與JSON格式字符串的相互轉換 詳解JavaScript中js對象與JSON格式字符串的相互轉換 

其中 (1)、(3)、(4)的執行結果說明,JSON解析器的stringify()函數對于js對象是fou符合JSON格式是不加限定,都可以把js對象轉換成JSON格式字符串。

(2)的執行結果說明,js對象中如果沒有JSON表示的值(比如函數和undefined)將會被排除。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女