採用Ajax的項目開發過程當中,常常須要將JSON格式的字符串返回到前端,前端解析成JS對象(JSON )。
ECMA-262(E3) 中沒有將JSON概念寫到標準中,但在 ECMA-262(E5) 中JSON的概念被正式引入了,包括全局的JSON對象和Date的toJSON方法。
1,eval方式解析,恐怕這是最先的解析方式了。 html
1 前端 2 json 3 瀏覽器 4spa |
function strToJson(str){ htm var json = eval('(' + str + ')'); 對象 return json; blog }開發 |
2,new Function形式,比較怪異哦。
1 2 3 4 |
function strToJson(str){ var json = (new Function("return " + str))(); return json; } |
IE6/7中當字符串中含有換行(\n)時,new Function不能解析,但eval卻能夠。
3,使用全局的JSON對象。
1 2 3 |
function strToJson(str){ return JSON.parse(str); } |
目前IE8(S)/Firefox3.5+/Chrome4/Safari4/Opera10 已實現了該方法。
使用JSON.parse需嚴格遵照JSON規範,如屬性都需用引號引發來,以下
1 2 |
var str = '{name:"jack"}'; var obj = JSON.parse(str); // --> parse error |
name沒有用引號引發來,使用JSON.parse全部瀏覽器中均拋異常,解析失敗。而前兩種方式則沒問題。