JavaScript转换与解析JSON方法实例详解


Posted in Javascript onNovember 24, 2015

本文实例讲述了JavaScript转换与解析JSON方法。分享给大家供大家参考,具体如下:

json格式数据如下:

var json = { 'jquery': [{ "id": "1", "type": "ASP.NET", "title": "JSON全解析"}] }
    alert(json.jquery[0].id);
    alert(json.jquery[0].type);
    alert(json.jquery[0].title);

javascript解析json数据:

window.onload = function() {
 var json = { "China": "[{'City':'上海','value':'1'},{'City':'南京','value':'2'},{'City':'杭州','value':'3'},{'City':'武汉','value':'4'}]" }
 var datas = eval(json.China);
 for (var i = 0; i < datas.length; i++) 
 {
  alert(datas[i].City);
  alert(datas[i].value);
 }
}

补充:jQuery解析json方法:

使用eval函数来解析,jquery的each方法来遍历

用JQuery解析JSON数据的方法,作为JQuery异步请求的传输对象,JQuery请求后返回的结果是json对象,这里考虑的都是服务器返回JSON形式的字符串的形式,对于利用JSONObject等插件封装的JSON对象,与此亦是大同小异,这里不再做说明。

这里首先给出JSON字符串集,字符串集如下:

var data=" 
{ 
root: 
[ 
  {name:'1',value:'0'}, 
  {name:'6101',value:'北京市'}, 
  {name:'6102',value:'天津市'}, 
  {name:'6103',value:'上海市'}, 
  {name:'6104',value:'重庆市'}, 
]
}";

这里以JQuery异步获取的数据类型——json对象和字符串为依据,分别介绍两种方式获取到的结果处理方式。

eval()

对于服务器返回的JSON字符串,如果jquery异步请求没做类型说明,或者以字符串方式接受,那么需要做一次对象化处理,方式不是太麻烦,就是将该字符串放于eval()中执行一次。这种方式也适合以普通javascipt方式获取json对象,以下举例说明:

// 转换为json对象
var dataObj=eval("("+data+")");

为什么要 eval这里要添加 ("("+data+")"); 呢?

原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。

加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语句(statement)来执行。举一个例子,例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始和结束标记,那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的:

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

对于这种写法,在JS中,可以到处看到。如: (function()) {}(); 做闭包操作时等。

//输出root的子对象数量 
alert(dataObj.root.length);
$.each(dataObj.root,fucntion(idx,item){ 
  if(idx==0){ 
    return true; 
  } 
  //输出每个root子对象的名称和值 
  alert("name:"+item.name+",value:"+item.value); 
})

对于一般的js生成json对象,只需要将$.each()方法替换为for语句即可,其他不变。

服务器返回的JSON字符串

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

$.getJSON("http://www.xxxx.com/",{param:"gaoyusi"},function(data){ 
  //此处返回的data已经是json对象 
  //以下其他操作同第一种情况 
  $.each(data.root,function(idx,item){ 
    if(idx==0){ 
      //同countinue,返回false同break 
      return true;
    } 
    alert("name:"+item.name+",value:"+item.value); 
  }); 
});

这里特别需要注意的是方式1中的eval()方法是动态执行其中字符串(可能是js脚本)的,这样很容易会造成系统的安全问题。所以可以采用一些规避了eval()的第三方客户端脚本库,比如JSON in JavaScript就提供了一个不超过3k的脚本库。

第二种解析方式就是使用Function对象来完成,它的典型应用就是在JQuery中的AJAX方法下的success等对于返回数据data的解析。

var json='{"name":"CJ","age":18}';
data =(new Function("","return "+json))();

此时的data就是一个会解析成一个json对象了。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
javascript比较文档位置
Apr 08 Javascript
JavaScript高级程序设计(第3版)学习笔记13 ECMAScript5新特性
Oct 11 Javascript
jquery 元素控制(追加元素/追加内容)介绍及应用
Apr 21 Javascript
关于jQuery判断元素是否存在的问题示例探讨
Jul 21 Javascript
js实现window.open不被拦截的解决方法汇总
Oct 30 Javascript
node.js中的path.resolve方法使用说明
Dec 08 Javascript
javascript实现可键盘控制的抽奖系统
Mar 10 Javascript
JS无缝滚动效果实现方法分析
Dec 21 Javascript
jquery插件开发之选项卡制作详解
Aug 30 jQuery
浅析前端路由简介以及vue-router实现原理
Jun 01 Javascript
javascript创建元素和删除元素实例小结
Jun 19 Javascript
JS时间戳与日期格式互相转换的简单方法示例
Jan 30 Javascript
jQuery实现带分组数据的Table表头排序实例分析
Nov 24 #Javascript
JS数组排序技巧汇总(冒泡、sort、快速、希尔等排序)
Nov 24 #Javascript
JS获取数组最大值、最小值及长度的方法
Nov 24 #Javascript
基于jquery实现日历签到功能
Sep 11 #Javascript
Jquery1.9.1源码分析系列(六)延时对象应用之jQuery.ready
Nov 24 #Javascript
如何解决ligerUI布局时Center中的Tab高度大小
Nov 24 #Javascript
JS实现图片高亮展示效果实例
Nov 24 #Javascript
You might like
php地址引用(php地址引用的效率问题)
2012/03/23 PHP
Laravel框架中实现使用阿里云ACE缓存服务
2015/02/10 PHP
解决PHP Opcache 缓存刷新、代码重载出现无法更新代码的问题
2020/08/24 PHP
nodejs教程之环境安装及运行
2014/11/21 NodeJs
javascript中replace( )方法的使用
2015/04/24 Javascript
Bootstrap CSS组件之下拉菜单(dropdown)
2016/12/17 Javascript
js遍历json的key和value的实例
2017/01/22 Javascript
jQuery插件FusionCharts实现的MSBar2D图效果示例【附demo源码】
2017/03/24 jQuery
jQuery EasyUI tree增加搜索功能的实现方法
2017/04/27 jQuery
Javascript实现数组中的元素上下移动
2017/04/28 Javascript
JS中call和apply函数用法实例分析
2018/06/20 Javascript
JavaScript设计模式之装饰者模式实例详解
2019/01/17 Javascript
ES6 Generator函数的应用实例分析
2019/06/26 Javascript
使用VueCli3+TypeScript+Vuex一步步构建todoList的方法
2019/07/25 Javascript
python显示天气预报
2014/03/02 Python
在Python中操作字典之fromkeys()方法的使用
2015/05/21 Python
pandas把dataframe转成Series,改变列中值的类型方法
2018/04/10 Python
pandas 把数据写入txt文件每行固定写入一定数量的值方法
2018/12/28 Python
Django使用redis缓存服务器的实现代码示例
2019/04/28 Python
python实现自动化上线脚本的示例
2019/07/01 Python
Python 实现自动导入缺失的库
2019/10/29 Python
Python实现画图软件功能方法详解
2020/07/28 Python
css3的动画特效之动画序列(animation)
2017/12/22 HTML / CSS
银河香水:Galaxy Perfume
2019/03/25 全球购物
意大利比基尼品牌:MISS BIKINI
2019/11/02 全球购物
《狐假虎威》教学反思
2014/02/07 职场文书
大学信息公开实施方案
2014/03/09 职场文书
小学新学期寄语
2014/04/02 职场文书
数学教研活动总结
2014/07/02 职场文书
通报表扬范文
2015/01/17 职场文书
2015年教师学期工作总结
2015/04/30 职场文书
安全主题班会教案
2015/08/12 职场文书
小学远程教育工作总结
2015/08/13 职场文书
用position:sticky完美解决小程序吸顶问题的实现方法
2021/04/24 HTML / CSS
SQL模糊查询报:ORA-00909:参数个数无效问题的解决
2021/06/21 Oracle
SpringBoot实现quartz定时任务可视化管理功能
2021/08/30 Java/Android