首页 / JSON / JSON.parse和eval的区别
JSON.parse和eval的区别
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了JSON.parse和eval的区别,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1398字,纯文字阅读大概需要2分钟。
内容图文

最近在来上海出差,基于APPCAN开发,看到文档里面有个JOSN.parse(),之前接触的JS方法比较少,就勤劳点多做做笔记了, 转了一片文章; JSON
(JavaScript Object Notation)是一种轻量级的数据格式,采用完全独立于语言的文本格式,是理想的数据交换格式。同时,JSON是Javascript原生格式,这意 味着在javascript中处理JSON数据不需要任何特殊的API或工具包,而且效率非常高。
基本 格 式:
varjsonData=‘{ "data1":"Hello,", "data2":"world!" }‘
调用方法jsonData.data1,jsonData.data2
很多json数据存入数组
var jsonData=[
{"name":"LiLei","age":19,"sex":"male"},
{"name":"HanMei","age":18,"sex":"famale"}
]
调用方法jsonData[0].name,jsonData[1].sex
总体而言,json是相对比较容易的理解和使用的,但同时存在很多的陷阱,如果不注意的话很容易掉进去。
json的的解析方法
json的解析方法共有两种:eval_r() 和 JSON.parse(),使用方法如下:
var jsonData = ‘{ "data1":"Hello,", "data2":"world! }‘;
var evalJson=
eval_r(‘(‘+jsonData+‘)‘);
var jsonParseJson=JSON.parse(jsonData);
这样就把jsonData这个json格式的字符串转换成了JSON对象。
二者的区别如下:
var value = 1;
var jsonstr = ‘{"data1":"hello","data2":++value}‘;
var data1 = eval_r(‘(‘+jsonstr+‘)‘);
console.log(data1);//这时value值为2
var data2=JSON.parse(jsonstr);
console.log(data2);//报错![]()
可以看到控制输出台的结果,第一个eval_r()顺利执行,第二个报错了。 从上例就可以明显地看出,eval在解析字符串时,会执行该字符串中的代码(这样的后果是相当恶劣的),如上例中,由于用eval解析一个json字符串而造成原先的value的值改变。
《高性能Javascript》一书即指出:
警告:关于JSON和eval需要注意的是:在代码中使用eval是很危险的,特别是用它执行第三方的JSON数据(其中可能包含恶意代码)时,尽可能使用JSON.parse()方法解析字符串本身。该方法可以捕捉JSON中的语法错误,并允许你传入一个函数,用来过滤或转换解析结果。如果此方法以备Firfox 3.5 、IE8 及 Safari 4 原生支持。大多数javascript类库包含的JSON解析代码会直接调用原生版本,如果没有原生支持的话,会调用一个略微不那么强大的非原生版本来处理。
原文:http://my.oschina.net/xuqianwen/blog/515713
内容总结
以上是互联网集市为您收集整理的JSON.parse和eval的区别全部内容,希望文章能够帮你解决JSON.parse和eval的区别所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。