色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

javascript解析json格式的數(shù)據(jù)方法詳解

瀏覽:5日期:2023-10-18 13:57:50

JSON (JavaScript Object Notation)是一種簡單的數(shù)據(jù)格式,比xml更輕巧。 它是 JavaScript 原生格式,這意味著在 JavaScript 中處理 JSON 數(shù)據(jù)不需要任何特殊的 API 或工具包。那么如何用JavaScript來解析json呢?

首先,科普一下json。在json中,有兩種結(jié)構(gòu):對(duì)象和數(shù)組。

一個(gè)對(duì)象以“{”(左括號(hào))開始,“}”(右括號(hào))結(jié)束。每個(gè)“名稱”后跟一個(gè)“:”(冒號(hào));“‘名稱/值’ 對(duì)”之間運(yùn)用 “,”(逗號(hào))分隔。 名稱用引號(hào)括起來;值如果是字符串則必須用括號(hào),數(shù)值型則不須要。例如:var o={“key”:”value”};數(shù)組是值(value)的有序集合。一個(gè)數(shù)組以“[”(左中括號(hào))開始,“]”(右中括號(hào))結(jié)束。值之間運(yùn)用 “,”(逗號(hào))分隔。var array = [{“name”:”tom”},{“name”:”jake”}];在數(shù)據(jù)傳輸流程中,json是以字符串的形式傳遞的,而JS操作的是JSON對(duì)象,所以,JSON對(duì)象和JSON字符串之間的相互轉(zhuǎn)換是關(guān)鍵。 json字符串:var str=’{“key”:”value”}’; json對(duì)象:var o={“key”:”value”};

1. json字符串轉(zhuǎn)化為json對(duì)象

可以通過JavaScript的eval()函數(shù)來進(jìn)行解析,代碼如下:

<script type='text/javascript'> var json = ’{'key':'value','jian':'zhi'}’; var obj = eval('(' + json + ')'); console.log(obj); //控制臺(tái)返回 Object console.log(obj.key); //控制臺(tái)返回 value console.log(obj.jian); //控制臺(tái)返回 zhi</script>

或者通過JSON.parse()方法來解析,代碼如下:

var json = ’{'key':'value','jian':'zhi'}’;var obj =JSON.parse(json);console.log(obj); //控制臺(tái)返回 Objectconsole.log(obj.key); //控制臺(tái)返回 valueconsole.log(obj.jian); //控制臺(tái)返回 zhi

既然這兩種方法都可以解析json字符串,那么我們究竟使用哪種呢?在這之前,我們先來做一個(gè)測(cè)試:

var value = 1;var jsonstr = ’{'name':'jifeng','company':'taobao','value':++value}’;var json1 = eval(’(’+jsonstr+’)’);console.log(json1); //控制臺(tái)返回 Objectconsole.log(’value: ’+ value); //控制臺(tái)返回 value 2

我的天,evel方法竟然會(huì)執(zhí)行json字符串里的代碼!!

我們?cè)倏匆幌翵SON.parse()方法:

var value = 1;var jsonstr = ’{'name':'jifeng','company':'taobao','value':++value}’;var json2 = JSON.parse(jsonstr);console.log(json2);console.log(’value: ’+ value); //控制臺(tái)報(bào)錯(cuò)Unexpected token + in JSON at position

現(xiàn)在知道怎么選擇了吧。

eval()方法是極其不安全的,尤其是在解析第三方數(shù)據(jù)的時(shí)候,萬一第三方數(shù)據(jù)給你加點(diǎn)惡意代碼什么的你不就完了么?所以,JSON.parse()才是正確的選擇,當(dāng)然,有些瀏覽器不支持這個(gè)方法, 可以到https://github.com/douglascrockford/JSON-js/blob/master/json2.js 下載json2.js,添加到你的hlml中就可以了。

除此之外還有一個(gè) jsonStr.parseJSON()的方法,也可以將json字符串轉(zhuǎn)化為json對(duì)象,同樣需要json2.js包的支持。

2.json對(duì)象轉(zhuǎn)化為json字符串

話不多說,先看代碼:

var json = ’{'key':'value','jian':'zhi'}’;var obj =JSON.parse(json);var str=JSON.stringify(obj);console.log(str); //控制臺(tái)返回 {'key':'value','jian':'zhi'}

這里我們用到了和JSON.parse(str) 相對(duì)應(yīng)的方法JSON.stringify(obj)。

同樣,還有一個(gè)方法叫做obj.toJSONString()也可以將json對(duì)象轉(zhuǎn)化為json字符串,與 jsonStr.parseJSON()相對(duì)應(yīng)。

3.json字符數(shù)組轉(zhuǎn)化為json數(shù)組

這個(gè)轉(zhuǎn)化和字符串轉(zhuǎn)對(duì)象是一樣的,只是操作json數(shù)組的方式與操作json對(duì)象的方式稍有不同而已。看一段代碼:

var arrayStr = ’[{'name':'tom','age':'18'},{'name':'jake','age':'20'}]’;var arrayObj =JSON.parse(arrayStr);console.log(arrayObj); //控制臺(tái)返回 Array[2]console.log(arrayObj[0]); //控制臺(tái)返回 Objectconsole.log(arrayObj[0].name); //控制臺(tái)返回 tomconsole.log(arrayObj[1].age); //控制臺(tái)返回 20

對(duì)于json數(shù)組,可以通過下標(biāo)來進(jìn)行訪問。由于它是一個(gè)數(shù)組,所以也可以通過for循環(huán)進(jìn)行遍歷。

4.jquery解析json字符串

簡單地提一下jquery。在使用jquery的ajax功能時(shí),有一個(gè)dataType屬性,可以將這個(gè)屬性設(shè)置為json或者利用$.getJSON()方法獲得服務(wù)器返回的值,這個(gè)返回值就是一個(gè)json對(duì)象,所以就不需要再做轉(zhuǎn)化。

當(dāng)然,jquery也提供了轉(zhuǎn)換的函數(shù) $.parseJSON(string); 這個(gè)和之前講的JSON.parse()得用法是一樣的,具體怎么使用,看個(gè)人喜好。

到此這篇關(guān)于javascript解析json格式的數(shù)據(jù)方法詳解的文章就介紹到這了,更多相關(guān)javascript解析json格式的數(shù)據(jù)內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 奇米888四色在线精品 | 在线播放波多野结衣 | 成人免费在线播放视频 | 国产精品分类视频分类一区 | 日韩偷拍自拍 | 免费在线视频成人 | 99精品国产兔费观看久久99 | a级毛片在线观看 | 99精品视频一区在线视频免费观看 | 久久精品观看 | 久久99国产精品久久99无号码 | 91香蕉国产观看免费人人 | 99热久久国产综合精品久久国产 | 欧美大片aaaa一级毛片 | 国产精品久久久久久小说 | 手机在线观看精品国产片 | 成人国产午夜在线视频 | 亚洲六月丁香六月婷婷蜜芽 | xxxwww在线播放 | 亚洲在线高清 | 国内精品久久影院 | 欧美日韩在线观看一区二区 | 最新国产美女一区二区三区 | 成人午夜大片免费看爽爽爽 | 毛片在线播放网址 | 波多野结衣视频免费在线观看 | 日本成人中文字幕 | 免费毛片视频网站 | 国内自拍第五一页 | 精品国产亚洲一区二区在线3d | 日本加勒比在线观看 | 99视频九九精品视频在线观看 | 日韩中文字幕在线免费观看 | 久久3| 中文精品久久久久国产不卡 | 亚洲男人天堂2018 | 91精品国产一区二区三区左线 | 日本一级特黄毛片高清视频 | 中文字幕福利 | 日韩欧美亚洲国产 | 欧美色视频日本片高清在线观看 |