因為JSON 是 javascript 的一個(gè)子集,所以,在javascript 中使用JSON是非常簡(jiǎn)單的。
js 代碼
- var myJSONObject = {"bindings": [
- {"ircEvent": "PRIVMSG", "method": "newURI", "regex": "^http://.*"},
- {"ircEvent": "PRIVMSG", "method": "deleteURI", "regex": "^delete.*"},
- {"ircEvent": "PRIVMSG", "method": "randomURI", "regex": "^random.*"}
- ]
- };
在上面的例子中,我們創(chuàng )建了只包含一個(gè)成員
"bindings" 的一個(gè)對象,bindings 則包含了一個(gè)由3個(gè)對象組成的數組。這3個(gè)對象都包含3個(gè)成員:"ircEvent", "method","regex"。
在javascript 中, 成員可以通過(guò)“點(diǎn)號”來(lái)獲取。
比如:
js 代碼
- myJSONObject.bindings[0].method
通過(guò)eval() 函數可以將JSON字符串轉化為對象。
js 代碼
- var myObject = eval('(' + myJSONtext + ')');
eval 函數非???,但是它可以編譯任何 javascirpt 代碼,這樣的話(huà)就可能產(chǎn)生安全的問(wèn)題。eval 的使用是基于傳入的代碼參數是可靠的假設的,有一些情況下,可能客戶(hù)端是不可信任的。
如果基于安全的考慮的話(huà),最好是使用一個(gè) JSON 解析器。 一個(gè) JSON 解析器將只接受 JSON 文本。所以是更安全的。
js 代碼
- var myObject = JSON.parse(myJSONtext, filter);
可選的 filter 參數將遍歷每一個(gè)value key 值對, 并進(jìn)行相關(guān)的處理。如:
js 代碼
- myData = JSON.parse(text, function (key, value) {
- return key.indexOf('date') >= 0 ? new Date(value) : value; });
stringifier 函數的作用跟 parse 相反, 用來(lái)將一個(gè)js對象轉換為 JSON 文本。
js 代碼
- var myJSONText = JSON.stringifier(myObject);
這里是一個(gè)開(kāi)源的 JSON parser and JSON stringifier
本站僅提供存儲服務(wù),所有內容均由用戶(hù)發(fā)布,如發(fā)現有害或侵權內容,請
點(diǎn)擊舉報。