• jQuery解析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对象和字符串为依据,分别介绍两种方式获取到的结果处理方式。

    对于服务器返回的JSON字符串,如果jquery异步请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,方式不是太麻烦,就是将该字符串放于eval()中执行一次。这种方式也适合以普通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);   
    • })  

     

    对于服务器返回的JSON字符串,如果jquery异步请求将type(一般为这个配置属性)设为“json”,或者利用$.getJSON()方法获得服务器返回,那么就不需要eval()方法了,因为这时候得到的结果已经是json对象了,只需直接调用该对象即可,这里以$.getJSON方法为例说明数据处理方法:

    • $.getJSON("http://gaoyusi.blog.163.com/",{param:"gaoyusi"},function(data){   
    • //此处返回的data已经是json对象   
    • //以下其他操作同第一种情况   
    • $.each(data.root,function(idx,item){   
    • if(idx==0){   
    • return true;//同countinue,返回false同break   
    • }  
    •  
    • alert("name:"+item.name+",value:"+item.value);  
    •  
    • });   
    • }); 
  • 相关阅读:
    POJ3159 Candies —— 差分约束 spfa
    POJ1511 Invitation Cards —— 最短路spfa
    POJ1860 Currency Exchange —— spfa求正环
    POJ3259 Wormholes —— spfa求负环
    POJ3660 Cow Contest —— Floyd 传递闭包
    POJ3268 Silver Cow Party —— 最短路
    POJ1797 Heavy Transportation —— 最短路变形
    POJ2253 Frogger —— 最短路变形
    POJ1759 Garland —— 二分
    POJ3685 Matrix —— 二分
  • 原文地址:https://www.cnblogs.com/linzheng/p/1877109.html
Copyright © 2020-2023  润新知