原文連結:http://www.sitepen.com/blog/2012/01/05/native-json-parsing-in-dojo/
原作者:Kris Zyp
Dojo1.7引入了一個新的模組:dojo/json。該模組與原有的dojo.fromJson和dojo.toJson函數的不同點在於,它基於JavaScript語言內建支援的JSON API。它還採用了內建的JSON解析與序列化功能(如果存在的話),因此在任何瀏覽器上都能達到最快的速度。
新的API用起來很簡單,而且如果你用過json.org函數庫或者瀏覽器內建函數的話,就會更容易上手。一旦載入了"dojo/json"模組並賦予變數JSON後,我們就能使用其中的parse和stringify函數了。例如要解析一個JSON字串:
define(["dojo/json"], function(JSON){ var jsonStr = '{"name": "value"}'; var object = JSON.parse(jsonStr); object.name -> "value";});
如果瀏覽器支援,在這個parse函數中就會使用內建的解析函數,否則的話就退化為Dojo自己的實現。
反過來,要將一個對象序列化為JSON字串:
define(["dojo/json"], function(JSON){ var object = {"name": "value"}; var jsonStr = JSON.stringify(object); jsonStr -> '{"name": "value"}'});
日期資料的序列化
新的JSON模組現在已能夠正確地序列化日期資料。以前dojo.fromJson會將日期對象序列化為"{}",現在則會自動轉成標準日期格式( UTC的ISO標準格式)。
內建函數的效能 - 保持輕量
新的JSON模組通過has()函數來決定是否採用內建的JSON功能。這不僅僅是一種功能檢測,它還意味著當你需要針對特定瀏覽器打包時,對於最新的主流瀏覽器而言,該模組只有幾個位元組的大小,這對於行動裝置 App是非常有價值的。
遺留函數dojo.fromJson和dojo.toJson還將在於Dojo base中繼續存在一段時間,但出於效能以及與標準的一致性的考慮,推薦採用這個dojo/json包中的parse和stringify函數。