天天看點

javascript 中使用JSON

因為JSON 是 javascript 的一個子集,是以,在javascript 中使用JSON是非常簡單的。

js 代碼

var myJSONObject = {"bindings": [

{"ircEvent": "PRIVMSG", "method": "newURI", "regex": "^http://.*"},

{"ircEvent": "PRIVMSG", "method": "deleteURI", "regex": "^delete.*"},

{"ircEvent": "PRIVMSG", "method": "randomURI", "regex": "^random.*"}

]

};

在上面的例子中,我們建立了隻包含一個成員 "bindings" 的一個對象,bindings 則包含了一個由3個對象組成的數組。這3個對象都包含3個成員:"ircEvent", "method","regex"。

在javascript 中, 成員可以通過“點号”來擷取。

比如:

myJSONObject.bindings[0].method

通過eval() 函數可以将JSON字元串轉化為對象。

var myObject = eval('(' + myJSONtext + ')');

eval 函數非常快,但是它可以編譯任何 javascirpt 代碼,這樣的話就可能産生安全的問題。eval 的使用是基于傳入的代碼參數是可靠的假設的,有一些情況下,可能用戶端是不可信任的。

如果基于安全的考慮的話,最好是使用一個 JSON 解析器。 一個 JSON 解析器将隻接受 JSON 文本。是以是更安全的。

var myObject = JSON.parse(myJSONtext, filter);

可選的 filter 參數将周遊每一個value key 值對, 并進行相關的處理。如:

stringifier 函數的作用跟 parse 相反, 用來将一個js對象轉換為 JSON 文本。

<a href="http://www.json.org/json2.js">JSON parser and JSON stringifier</a>

myData = JSON.parse(text, function (key, value) { 

return key.indexOf('date') &gt;= 0 ? new Date(value) : value; });

var myJSONText = JSON.stringifier(myObject);

這裡是一個開源的

描述: 一個開源的 JSON parser and JSON stringifier

本文轉自linzheng 51CTO部落格,原文連結:http://blog.51cto.com/linzheng/1081646

繼續閱讀