jquery中JSON的解析方式
來源:易賢網 閱讀:917 次 日期:2015-05-05 15:16:55
溫馨提示:易賢網小編為您整理了“jquery中JSON的解析方式”,方便廣大網友查閱!

考慮都考慮的是服務器返回的是JSON形式的字符串的形式,對于利用JSONObject等插件封裝的JSON對象,與此亦是大同小異,這里不再做說明。

代碼如下:

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異步獲取的數據類型——json對象和字符串為依據,分別介紹兩種方式獲取到的結果處理方式。

1.對于服務器返回的JSON字符串,如果jquery異步請求沒做類型說明,或者以字符串方式接受,那么需要做一次對象化處理,方式不是太麻煩,就是將該字符串放于eval()中執(zhí)行一次。這種

方式也適合以普通javascipt方式獲取json對象,以下舉例說明:

代碼如下:

var dataObj=eval("("+data+")");//轉換為json對象

alert(dataObj.root.length);//輸出root的子對象數量

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

if(idx==0){

return true;

}

//輸出每個root子對象的名稱和值

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

})

注:對于一般的js生成json對象,只需要將$.each()方法替換為for語句即可,其他不變。

2.對于服務器返回的JSON字符串,如果jquery異步請求將type(一般為這個配置屬性)設為“json”,或者利用$.getJSON()方法獲得服務器返回,那么就不需要eval()方法了,因為這時候

得到的結果已經是json對象了,只需直接調用該對象即可,這里以$.getJSON方法為例說明數據處理方法:

代碼如下:

$.getJSON("){

//此處返回的data已經是json對象

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

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

if(idx==0){

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

}

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

});

});

以上就是本文關于jQuery解析json的全部內容了,希望大家能夠喜歡。

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
易賢網手機網站地址:jquery中JSON的解析方式
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點

版權所有:易賢網