在JS中將JSON的字符串解析成JSON數(shù)據(jù)格式一般有兩種方式
來(lái)源:易賢網(wǎng) 閱讀:871 次 日期:2015-02-03 15:17:52
溫馨提示:易賢網(wǎng)小編為您整理了“在JS中將JSON的字符串解析成JSON數(shù)據(jù)格式一般有兩種方式”,方便廣大網(wǎng)友查閱!

在JS中將JSON的字符串解析成JSON數(shù)據(jù)格式,一般有兩種方式:

1.一種為使用eval()函數(shù)。

2. 使用Function對(duì)象來(lái)進(jìn)行返回解析。

第一種解析方式:使用eval函數(shù)來(lái)解析,并且使用jQuery的each方法來(lái)遍歷

用jQuery解析JSON數(shù)據(jù)的方法,作為jQuery異步請(qǐng)求的傳輸對(duì)象,jQuery請(qǐng)求后返回的結(jié)果是json對(duì)象,這里考慮的都是服務(wù)器返回JSON形式的字符串的形式,對(duì)于利用JSONObject等插件封裝的JSON對(duì)象,與此亦是大同小異,這里不再做說(shuō)明。

這里首先給出JSON字符串集,字符串集如下:

復(fù)制代碼 代碼如下:var data = " {

root:

[

{name: '1', value: '0'},

{name: '6101', value: '北京市'},

{name: '6102', value: '天津市'},

{name: '6103', value: '上海市'},

{name: '6104', value: '重慶市'},

{name: '6105', value: '渭南市'},

{name: '6106', value: '延安市'},

{name: '6107', value: '漢中市'},

{name: '6108', value: '榆林市'},

{name: '6109', value: '安康市'},

{name: '6110', value: '商洛市'}

]

}

";

這里以jQuery異步獲取的數(shù)據(jù)類(lèi)型——json對(duì)象和字符串為依據(jù),分別介紹兩種方式獲取到的結(jié)果處理方式。

1、對(duì)于服務(wù)器返回的JSON字符串,如果jQuery異步請(qǐng)求沒(méi)做類(lèi)型說(shuō)明,或者以字符串方式接受,那么需要做一次對(duì)象化處理,方式不是太麻煩,就是將該字符串放于eval()中執(zhí)行一次。這種方式也適合以普通JavaScipt方式獲取json對(duì)象,以下舉例說(shuō)明:

復(fù)制代碼 代碼如下:var dataObj = eval("(" + data + ")"); // 轉(zhuǎn)換為json對(duì)象

為什么要 eval這里要添加 “("(" + data + ")");” 呢?

原因在于:eval本身的問(wèn)題。 由于json是以“{}”的方式來(lái)開(kāi)始以及結(jié)束的,在JS中,它會(huì)被當(dāng)成一個(gè)語(yǔ)句塊來(lái)處理,所以必須強(qiáng)制性的將它轉(zhuǎn)換成一種表達(dá)式。

加上圓括號(hào)的目的是迫使eval函數(shù)在處理JavaScript代碼的時(shí)候強(qiáng)制將括號(hào)內(nèi)的表達(dá)式(expression)轉(zhuǎn)化為對(duì)象,而不是作為語(yǔ)句(statement)來(lái)執(zhí)行。舉一個(gè)例子,例如對(duì)象字面量{},如若不加外層的括號(hào),那么eval會(huì)將大括號(hào)識(shí)別為JavaScript代碼塊的開(kāi)始和結(jié)束標(biāo)記,那么{}將會(huì)被認(rèn)為是執(zhí)行了一句空語(yǔ)句。所以下面兩個(gè)執(zhí)行結(jié)果是不同的:

復(fù)制代碼 代碼如下:

alert(eval("{}"); // return undefined

alert(eval("({})");// return object[Object]

對(duì)于這種寫(xiě)法,在JS中,可以到處看到。

如: (function(){})(); 做閉包操作時(shí)等。

復(fù)制代碼 代碼如下:alert(dataObj.root.length);//輸出root的子對(duì)象數(shù)量

$.each(dataObj.root, fucntion(idx, item) {

if (idx == 0) {

return true;

}

//輸出每個(gè)root子對(duì)象的名稱和值

alert("name:" + item.name + ",value:" + item.value);

})

2、對(duì)于服務(wù)器返回的JSON字符串,如果jQuery異步請(qǐng)求將type(一般為這個(gè)配置屬性)設(shè)為“json”,或者利用$.getJSON()方法獲得服務(wù)器返回,那么就不需要eval()方法了,因?yàn)檫@時(shí)候得到的結(jié)果已經(jīng)是json對(duì)象了,只需直接調(diào)用該對(duì)象即可,這里以$.getJSON方法為例說(shuō)明數(shù)據(jù)處理方法:

復(fù)制代碼 代碼如下:$.getJSON("", {param: "snsgou"}, function (data) {

// 此處返回的data已經(jīng)是json對(duì)象

// 以下其他操作同第一種情況

$.each(data.root, function (index, item) {

if (index == 0) {

return true; // 同countinue,返回false同break

}

alert("name:" + item.name + ",value:" + item.value);

});

});

這里特別需要注意的是方式1中的eval()方法是動(dòng)態(tài)執(zhí)行其中字符串(可能是js腳本)的,這樣很容易會(huì)造成系統(tǒng)的安全問(wèn)題。所以可以采用一些規(guī)避了eval()的第三方客戶端腳本庫(kù),比如JSON in JavaScript就提供了一個(gè)不超過(guò)3k的腳本庫(kù)。

第二種解析方式:使用Function對(duì)象來(lái)完成,它的典型應(yīng)用就是在jQuery中的AJAX方法下的success等對(duì)于返回?cái)?shù)據(jù)data的解析

復(fù)制代碼 代碼如下:var json='{"name":"CJ","age":18}';

data =(new Function("", "return " + json))();

此時(shí)的data就是一個(gè)會(huì)解析成一個(gè) json對(duì)象了。

最后的結(jié)論是:

代碼如下:

json字符串轉(zhuǎn)json對(duì)象,使用 (new Function("return " + jsonString))(); 來(lái)代替 eval('(' + jsonString + ')');

更多信息請(qǐng)查看IT技術(shù)專(zhuān)欄

更多信息請(qǐng)查看腳本欄目
下一篇:jQuery.fn解釋
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門(mén)公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽(tīng)報(bào)名

  • 報(bào)班類(lèi)型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專(zhuān)用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專(zhuān)用圖標(biāo)