JSONObject插件与JAVA语言插件大致相同,下面的几个例子都在枚举对应属性值均为整形。你可能想到,难道还能定义成别的类型?要回答这个问题,得先知道咱们这个枚举实现的原理,下面进行学习研究探讨。
对于利用JSONObject插件封装的JSON对象,与此亦是大同小异,这里不再做说明。 这里首先给出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对象和字符串为依据,分别介绍两种方式获取到的结果处理方式。 #t#
1.对于服务器返回的JSONObject插件,如果jquery异步请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,方式不是太麻烦,就是将该字符串放于eval()中执行一次。这种方式也适合以普通javascipt方式获取json对象,以下举例说明:
- var dataObj=eval("("+data+")");//转换为json对象
- alert(dataObj.root.length);//输出root的子对象数量
每种方法是使用一个长度为 130 的数组来测试,其中每个元素的长度是多种多样的,防止浏览器对一定长度的字符串做特殊的优化;每种方法测试了 1000 次;下面的结果显示,执行完这 1000 次需要的时间:
- $.getJSON("http://www.phpzixue.cn/",{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);
- });
- });