1. 程式人生 > >js陣列、物件與字串互轉

js陣列、物件與字串互轉

JSON.stringify 函式:陣列(物件)/物件轉化為字串

語法
JSON.stringify(obj/Array [, replacer] [, space])

示例1
此示例使用 JSON.stringify 將 contact 物件轉換為 JSON 文字。 定義 memberfilter 陣列以便只轉換 surname 和 phone 成員。 省略 firstname 成員。最後的\t(space)引數,感覺沒什麼實際用處,只是輸出格式更易讀吧。

<sctipt>
    var contact = new Object();
    contact.firstname = "Jesper"
; contact.surname = "Aaberg"; contact.phone = ["555-0100", "555-0120"]; var memberfilter = new Array(); memberfilter[0] = "surname"; memberfilter[1] = "phone"; var jsonText = JSON.stringify(contact, memberfilter, "\t"); console.log(jsonText); </script>

結果如下

如果沒有後面的\t,則輸出為一行
這裡寫圖片描述

示例2
此示例將 JSON.stringify 與一個數組一起使用。 replaceToUpper 函式將陣列中的每個字串轉換為大寫形式。

<sctipt>
    var continents = new Array();
    continents[0] = "Europe";
    continents[1] = "Asia";
    continents[2] = "Australia";
    continents[3] = "Antarctica";
    continents[4] = "North America";
    continents[5
] = "South America"; continents[6] = "Africa"; var jsonText = JSON.stringify(continents, replaceToUpper); //Output: // "EUROPE,ASIA,AUSTRALIA,ANTARCTICA,NORTH AMERICA,SOUTH AMERICA,AFRICA" function replaceToUpper(key, value) { return value.toString().toUpperCase(); } </script>

JSON.parse 函式:字串轉換為物件

語法
JSON.parse(jsonText [, reviver])

<script>
    var jsontext = '{"firstname":"Jesper","surname":"Aaberg","phone":["555-0100","555-0120"]}';
    var contact = JSON.parse(jsontext);
    document.write(contact.surname + ", " + contact.firstname); // Aaberg, Jesper
    document.write(contact.phone[0]);       // 555-0100
</script>
<script>
    var arr = ["a", "b", "c"];
    var str = JSON.stringify(arr);
    document.write(str);
    document.write ("<br/>");

    var newArr = JSON.parse(str);

    while (newArr.length > 0) {
        document.write(newArr.pop() + "<br/>");
    }

    // Output:
    // ["a","b","c"]
    // c
    // b
    // a
</script>

注:如果響應的格式為 JSONP 而非純 JSON,請在響應物件上嘗試此程式碼:

JavaScript
var fixedResponse = response.responseText.replace(/\\'/g, "'");
var jsonObj = JSON.parse(fixedResponse);