js 將json字符串轉(zhuǎn)換為json對象的方法解析
例如:
JSON字符串:
var str1 = '{ "name": "cxh", "sex": "man" }';
JSON對象:
var str2 = { "name": "cxh", "sex": "man" };
一、JSON字符串轉(zhuǎn)換為JSON對象
要使用上面的str1,必須使用下面的方法先轉(zhuǎn)化為JSON對象:
//由JSON字符串轉(zhuǎn)換為JSON對象
var obj = eval('(' + str + ')');
或者
var obj = str.parseJSON(); //由JSON字符串轉(zhuǎn)換為JSON對象
或者
var obj = JSON.parse(str); //由JSON字符串轉(zhuǎn)換為JSON對象
然后,就可以這樣讀取:
Alert(obj.name);
Alert(obj.sex);
特別注意:如果obj本來就是一個JSON對象,那么使用eval()函數(shù)轉(zhuǎn)換后(哪怕是多次轉(zhuǎn)換)還是JSON對象,但是使用parseJSON()函數(shù)處理后會有問題(拋出語法異常)。
二、可以使用toJSONString()或者全局方法JSON.stringify()將JSON對象轉(zhuǎn)化為JSON字符串。
例如:
var last=obj.toJSONString(); //將JSON對象轉(zhuǎn)化為JSON字符
或者
var last=JSON.stringify(obj); //將JSON對象轉(zhuǎn)化為JSON字符
alert(last);
注意:
上面的幾個方法中,除了eval()函數(shù)是js自帶的之外,其他的幾個方法都來自json.js包。新版本的 JSON 修改了 API,將 JSON.stringify() 和 JSON.parse() 兩個方法都注入到了 Javascript 的內(nèi)建對象里面,前者變成了 Object.toJSONString(),而后者變成了 String.parseJSON()。如果提示找不到toJSONString()和parseJSON()方法,則說明您的json包版本太低。
PS:本站還提供了幾款功能十分強(qiáng)大的json解析、轉(zhuǎn)換與格式化工具供大家選擇使用,相信對于大家接下來的json格式數(shù)據(jù)處理會有所幫助:
在線JSON代碼檢驗、檢驗、美化、格式化工具:
http://tools.jb51.net/code/json
在線XML/JSON互相轉(zhuǎn)換:
http://tools.jb51.net/code/xmljson
json代碼在線格式化/美化/壓縮/編輯/轉(zhuǎn)換工具:
http://tools.jb51.net/code/jsoncodeformat
C語言風(fēng)格/HTML/CSS/json代碼格式化美化工具:
http://tools.jb51.net/code/ccode_html_css_json
相關(guān)文章
bootstrap table實現(xiàn)合并單元格效果
這篇文章主要為大家詳細(xì)介紹了bootstrap table實現(xiàn)合并單元格效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12dtree 網(wǎng)頁樹狀菜單及傳遞對象集合到j(luò)s內(nèi),動態(tài)生成節(jié)點(diǎn)
最近要做一個聯(lián)系人的選擇框,選擇聯(lián)系人后,將聯(lián)系人的手機(jī)號添加到網(wǎng)頁的輸入框,可以支持復(fù)選框2012-04-04配置Grunt的Task時通配符支持和動態(tài)生成文件名問題
這篇文章主要介紹了配置Grunt的Task時通配符支持和動態(tài)生成文件名問題,需要的朋友可以參考下2015-09-09js實現(xiàn)一個可以兼容PC端和移動端的div拖動效果實例
這篇文章主要介紹了js實現(xiàn)一個可以兼容PC端和移動端的div拖動效果實例,具有一定的參考價值,有需要的可以了解一下。2016-12-12