js解析與序列化json數(shù)據(jù)(一)json.stringify()的基本用法
更新時(shí)間:2013年02月01日 12:01:20 作者:
對(duì)象有兩個(gè)方法:stringify()和parse()。在最簡(jiǎn)單的情況下,這兩個(gè)方法分別用于把JavaScript對(duì)象序列化為JSON字符串和把JSON字符串解析為原生JavaScript
早期的JSON解析器基本上就是使用JavaScript的eval()函數(shù)。由于JSON是JavaScript語法的自己,因此eval()函數(shù)可以解析、解釋并返回JavaScript的對(duì)象和數(shù)組。
ECMAScript 5對(duì)解析JSON的行為進(jìn)行了規(guī)范,定義了全局對(duì)象JSON。
JSON對(duì)象有兩個(gè)方法:stringify()和parse()。在最簡(jiǎn)單的情況下,這兩個(gè)方法分別用于把JavaScript對(duì)象序列化為JSON字符串和把JSON字符串解析為原生JavaScript。例如:
新建一個(gè)HTML:代碼如下:
<html>
<head>
<title></title>
<script type="text/javascript">
function init()
{
var book={
title:"JavaScript高級(jí)程序設(shè)計(jì)",
authors:[
"Nicholas C. Zakas"
],
edition:3,
year:2011
};
var jsonBook=JSON.stringify(book);
var objectBook=JSON.parse(jsonBook);
var title=objectBook.title;} </script> </head> <body> <input type="button" onclick="init()" value="測(cè)試" /> </body> </html>
默認(rèn)情況下,JSON.stringify()輸出的JSON字符串不包含任何空字符或縮進(jìn),因此保存在jsonBook中的字符串如下所示:
{"title":"JavaScript高級(jí)程序設(shè)計(jì)","authors":["Nicholas C. Zakas"],"edition":3,"year":2011}
在序列化JavaScript對(duì)象時(shí),所有函數(shù)及原型成員都會(huì)被有意忽略,不體現(xiàn)在結(jié)果中。此外,值為undefined的任何屬性也都會(huì)被跳過。結(jié)果中最終都是值為有效JSON數(shù)據(jù)類型的實(shí)例屬性。
注意,雖然book與objectBook具有相同的屬性,但它們是兩個(gè)獨(dú)立的、沒有任何關(guān)系的對(duì)象。如果傳給JSON.parse()的字符串不是有效的JSON,該方法會(huì)拋出錯(cuò)誤。
ECMAScript 5對(duì)解析JSON的行為進(jìn)行了規(guī)范,定義了全局對(duì)象JSON。
JSON對(duì)象有兩個(gè)方法:stringify()和parse()。在最簡(jiǎn)單的情況下,這兩個(gè)方法分別用于把JavaScript對(duì)象序列化為JSON字符串和把JSON字符串解析為原生JavaScript。例如:
新建一個(gè)HTML:代碼如下:
復(fù)制代碼 代碼如下:
<html>
<head>
<title></title>
<script type="text/javascript">
function init()
{
var book={
title:"JavaScript高級(jí)程序設(shè)計(jì)",
authors:[
"Nicholas C. Zakas"
],
edition:3,
year:2011
};
var jsonBook=JSON.stringify(book);
var objectBook=JSON.parse(jsonBook);
var title=objectBook.title;} </script> </head> <body> <input type="button" onclick="init()" value="測(cè)試" /> </body> </html>
默認(rèn)情況下,JSON.stringify()輸出的JSON字符串不包含任何空字符或縮進(jìn),因此保存在jsonBook中的字符串如下所示:
復(fù)制代碼 代碼如下:
{"title":"JavaScript高級(jí)程序設(shè)計(jì)","authors":["Nicholas C. Zakas"],"edition":3,"year":2011}
在序列化JavaScript對(duì)象時(shí),所有函數(shù)及原型成員都會(huì)被有意忽略,不體現(xiàn)在結(jié)果中。此外,值為undefined的任何屬性也都會(huì)被跳過。結(jié)果中最終都是值為有效JSON數(shù)據(jù)類型的實(shí)例屬性。
注意,雖然book與objectBook具有相同的屬性,但它們是兩個(gè)獨(dú)立的、沒有任何關(guān)系的對(duì)象。如果傳給JSON.parse()的字符串不是有效的JSON,該方法會(huì)拋出錯(cuò)誤。
您可能感興趣的文章:
- JSON PHP中,Json字符串反序列化成對(duì)象/數(shù)組的方法
- PHP中SERIALIZE和JSON的序列化與反序列化操作區(qū)別分析
- PHP的serialize序列化數(shù)據(jù)以及JSON格式化數(shù)據(jù)分析
- php json與xml序列化/反序列化
- php 中序列化和json使用介紹
- php中serialize序列化與json性能測(cè)試的示例分析
- jquery序列化form表單使用ajax提交后處理返回的json數(shù)據(jù)
- js解析與序列化json數(shù)據(jù)(二)序列化探討
- Json序列化和反序列化方法解析
- php中json?序列化為?[]?的弊端
相關(guān)文章
改進(jìn)版通過Json對(duì)象實(shí)現(xiàn)深復(fù)制的方法
改進(jìn)版通過Json對(duì)象實(shí)現(xiàn)深復(fù)制的方法,需要的朋友可以參考下2012-10-10深入淺析同源與跨域,jsonp(函數(shù)封裝),CORS原理
這篇文章主要介紹了同源與跨域,jsonp(函數(shù)封裝),CORS原理,從同源政策中Ajax限制,到跨域問題以及跨域問題的解決方法幫大家更加深入的去了解其中原理2021-08-08利用NodeJS的子進(jìn)程(child_process)調(diào)用系統(tǒng)命令的方法分享
child_process即子進(jìn)程可以創(chuàng)建一個(gè)系統(tǒng)子進(jìn)程并執(zhí)行shell命令,在與系統(tǒng)層面的交互上挺有用處2013-06-06Jquery+asp.net后臺(tái)數(shù)據(jù)傳到前臺(tái)js進(jìn)行解析的方法
我們經(jīng)常用jquery讀取后臺(tái)數(shù)據(jù),后臺(tái)返回?cái)?shù)據(jù)。后臺(tái)數(shù)據(jù)格式就有很多了,但是js里面沒有什么類型之分2014-05-05JSON與XML優(yōu)缺點(diǎn)對(duì)比分析
本文從各個(gè)方面向大家對(duì)比展示了json和xml的優(yōu)缺點(diǎn),十分的全面細(xì)致,有需要的小伙伴可以參考下。2015-07-07js解析與序列化json數(shù)據(jù)(三)json的解析探討
這一節(jié)我們主要討論json的解析,感興趣的朋友可以了解下,JSON.parse()方法也可以接收另一個(gè)參數(shù),該參數(shù)是一個(gè)函數(shù),將早每個(gè)鍵值對(duì)上調(diào)用,好了,話不多說,希望本文對(duì)你有所幫助2013-02-02