JavaScript中解析JSON数据的三种方法

释放双眼,带上耳机,听听看~!

概述

现在JSON格式在web开发中越来越受重视,特别是在使用ajax开发项目的过程中,经常需要将json格式的字符串返回到前端,前端解析成JS对象(JSON )。
ECMA-262(E3)中没有将JSON概念写到标准中,还好在 ECMA-262(E5)中JSON的概念被正式引入了,包括全局的JSON对象和Date的toJSON方法。
解析JSON数据的三种方法

eval()方法

解析JSON数据的最常用方法是使用javascript的eval()方法,代码如下:

代码如下:


1
2
3
4
5
6
7
8
1function toJson(str){  
2
3 var json = eval('(' + str + ')');  
4
5 return json;  
6
7}
8

1
2
1 该方法存在性能和安全方面的问题,不建议使用。  
2

new Function方法

代码如下:


1
2
3
4
5
6
7
8
1function toJson(str){  
2
3 var json = (new Function("return " + str))();  
4
5 return json;  
6
7}
8

1
2
1 **JSON.parse()方法**  
2

这种方法只支持IE8/Firefox3.5+/Chrome4/Safari4/Opera10 以上版本,这些浏览器都已经接近W3C标准,默认实现了toJSON方法。

代码如下:


1
2
3
4
5
6
1function toJson(str){  
2
3 return JSON.parse(str);  
4
5}
6

1
2
1 json2.js会在浏览器原生支持JSON.parse的时候选用原生版本,而且它跟ES5是API兼容的。在ES5还没完全普及的现状下,John Resig大神推荐用json2.js主要是为了现在就能用跟ES5兼容的API,日后能平滑过渡到ES5――只要去掉一个import就换过来了。
2

给TA打赏
共{{data.count}}人
人已打赏
安全技术

C++ lambda表达式

2022-1-11 12:36:11

安全技术

iptables命令

2021-8-18 16:36:11

个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索