JSON字符串和對象之間的轉換詳解
JSON(JavaScript Object Notation) 是JavaScript編程語言的一個子集。正因JSON是JavaScript的一個子集,所以它可清晰的運用于此語言中。
eval函數(shù) JSON文本轉換為對象
為了將JSON文本轉換為對象,可以使用eval函數(shù)。eval函數(shù)調(diào)用JavaScript編輯器。由于JSON是JavaScript的子集,因此編譯器將正確的解析文本并產(chǎn)生對象結構。文本必須括在括號中避免產(chǎn)生JavaScript的語法歧義。
var obj = eval('(' + JSONTest + ')');eval函數(shù)非??焖?。它可以編譯執(zhí)行任何JavaScript程序,因此產(chǎn)生了安全性問題。當使用可信任與完善的源代碼時才可以使用eval函數(shù)。這樣可以更安全的解析JSON文本。使用XmlHttp的web應用,頁面之間的通訊只允許同源,因此是可以信任的。但這卻不是完善的。如果服務器沒有嚴謹?shù)腏SON編碼,或者沒有嚴格的輸入驗證,那么可能傳送包括危險腳本的無效JSON文本。eval函數(shù)將執(zhí)行惡意的腳本。
JSON解釋器 JSON.parse、JSON.stringify
使用JSON解析器可以防止像eval函數(shù)轉換JSON文本為對象那樣的安全隱患。JSON解析器只能辨識JSON文本,拒絕所有腳本。提供了本地JSON支持的瀏覽器的JSON解析器將遠快于eval函數(shù)。
目前,F(xiàn)irefox、Opera、IE8以上版本也提供了本地JSON支持。其中,JSON解釋器提供的函數(shù)有:JSON.parse、JSON.stringify。
對于那些并不提供本地JSON支持的瀏覽器可以引入腳本json2.js,來實現(xiàn)JSON轉換功能。json2.js腳本可到https://github.com/douglascrockford/JSON-js/blob/master/json2.js頁面下載。
JSON.parse 函數(shù)
將JSON文本轉換為對象。
JSON.parse(text[, reviver])
參數(shù)
text
必選項。要轉換為對象的JSON文本。
reviver
可選項。該參數(shù)是個替換函數(shù)。在轉換中,遍歷的每個節(jié)點,都將執(zhí)行該函數(shù),該函數(shù)的返回值將替代轉換結果的相應節(jié)點值。
JSON.stringify 函數(shù)
將對象轉換為JSON文本。
JSON.stringify(value[, replacer[, space]])
參數(shù)
text
必選項。要轉換為JSON文本的對象。
reviver
可選項。該參數(shù)是個替換函數(shù)。在轉換中,遍歷的每個節(jié)點,都將執(zhí)行該函數(shù),該函數(shù)的返回值將替代轉換結果的相應節(jié)點值。
space
可選項。格式化輸出JSON文本縮進的空格數(shù)量。如果不提供該參數(shù)將不會格式化輸出。
參數(shù)reviver的委托類型
reviver(key, value)
reviver函數(shù)的中的this是當前所遍歷到的節(jié)點的父節(jié)點。當所遍歷的是根節(jié)點的時候,父節(jié)點是個Object對象,根節(jié)點是該對象的一個屬性,屬性名是空字符串。
參數(shù)
key
當父節(jié)點是數(shù)組Object,key為數(shù)組索引,否則key為Object屬性名。
value
節(jié)點值。
注:JSON不支持循環(huán)數(shù)據(jù)結構。
jQuery.parseJSON( jsonTex )
jQuery中也有將字符串轉為JSON格式的方法jQuery.parseJSON( json ),接受一個標準格式的 JSON 字符串,并返回解析后的 JavaScript (JSON)對象。當然如果有興趣可以自己封裝一個jQuery擴展,jQuery.stringifyJSON(obj)將JSON轉為字符串。
以上所述就是本文的全部內(nèi)容了希望大家能夠喜歡。
相關文章
js解析與序列化json數(shù)據(jù)(三)json的解析探討
這一節(jié)我們主要討論json的解析,感興趣的朋友可以了解下,JSON.parse()方法也可以接收另一個參數(shù),該參數(shù)是一個函數(shù),將早每個鍵值對上調(diào)用,好了,話不多說,希望本文對你有所幫助2013-02-02js+json用表格實現(xiàn)簡單網(wǎng)站左側導航
閑暇之余,制作一用表格實現(xiàn)的簡單的網(wǎng)站導航條,分享給大家。這里的數(shù)據(jù)基于json格式,學習json的朋友可以參考下。2010-04-04Jquery+asp.net后臺數(shù)據(jù)傳到前臺js進行解析的方法
我們經(jīng)常用jquery讀取后臺數(shù)據(jù),后臺返回數(shù)據(jù)。后臺數(shù)據(jù)格式就有很多了,但是js里面沒有什么類型之分2014-05-05