JSON.parse 与 eval() 对于解析json的问题(转)

from:https://www.cnblogs.com/zqzjs/p/4693958.html

1.eval()与JSOn.parse的不同

eval()

varc = 1;//全局变量varjsonstr1 = '{"name":"a","company":"b","value":++c}';varjson1 = eval('(' + jsonstr1 + ')');

console.log(json1.value);

c是全局变量为1,但是经过eval的解析,全局变量变成了2!(这样的写法是危险的)

JSON.parse

varc = 1;//全局变量varjsonstr1 = '{"name":"a","company":"b","value":++c}';varjson2 =JSON.parse(jsonstr1);

console.log(json2.value);

IE下报错:

谷歌下报错:

而JSON.parse则会报错。

2.在++c中加上双引号则就可以,因为它变成字符串了。

varc = 1;//全局变量varjsonstr1 = '{"name":"a","company":"b","value":“++c”}';varjson2 =JSON.parse(jsonstr1);

console.log(json2.value);

结果:

3.我想很多人在纠结双引号的问题,这里我们就来集中测试下。

a:JSON.parse

varc = 1;//全局变量vardate =newDate();

console.log(date.toLocaleDateString());//var jsonstr1 = '{"name":"a","company":"b","value":"++c"}';//键,值都有双引号varjsonstr2 = '{"name":"a","company":"b","value":++c}';//仅++c上午双引号//var jsonstr3 = '{name:"a",company:"b",value:"++c"}';//仅有值上有双引号//var jsonstr4 = '{name:a,company:b,value:++c}';//全无双引号//var json1 = JSON.parse(jsonstr1);varjson2 =JSON.parse(jsonstr2);//var json3 = JSON.parse(jsonstr3);//var json4 = JSON.parse(jsonstr4);//console.log(json1 );console.log(json2 );//console.log(json3);//console.log(json4);

结果依次为:

可见JSON.parse中只有第一种标准形式才会解析正确

b:eval()

varc = 1;//全局变量vardate =newDate();

console.log(date.toLocaleDateString());varjsonstr1 = '{"name":"a","company":"b","value":"++c"}';//键,值都有双引号//var jsonstr2 = '{"name":"a","company":"b","value":++c}';//仅++c上午双引号//var jsonstr3 = '{name:"a",company:"b",value:"++c"}';//仅有值上有双引号//var jsonstr4 = '{name:a,company:b,value:++c}';//全无双引号varjson1 = eval('('+jsonstr1+')');//var json2 = eval('('+jsonstr2+')');//var json3 = eval('('+jsonstr3+')');//var json4 = eval('('+jsonstr4+')');console.log(json1+"    "+json1.value );//console.log(json2+"    "+json2.value );//console.log(json3 + "    " + json3.value);//console.log(json4+"    "+json3.value);

结果依次为:

而eval中除了最后一种,其他都解析正确。

4.这时候还有一个问题:那就是为什么eval()解析的时候要加上括号?

我们先看看不加括号会怎么样:

varc = 1;//全局变量vardate =newDate();

console.log(date.toLocaleDateString());varjsonstr1 = '{"name":"a","company":"b","value":"++c"}';//键,值都有双引号varjson1 =eval(jsonstr1);

console.log(json1+"    "+json1.value );

结果:

这里不加就出错了。

那是因为eval()相当于一个执行环境,当你不加括号的时候,jsonstr1会被认为是一条复合语句。运行的时候就会逐个字符的解析。

但是加上括号的时候,jsonstr1就当做一个表达式去运算。从括号开始就被当做了对象进行识别。

5.然后你又会想到,那这个括号为什么要加“()”,不能加“{}”么?

答案是:当然能加“{}”,只不过就会报错而已~。— —!

这时候你要明吧json的格式是什么!

{"name":"a","company":"b"} 这就是标准形式。

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,281评论 19 139
  • 深入理解JavaScript系列文章,包括了原创,翻译,转载,整理等各类型文章,如果对你有用,请推荐支持一把,给大...
    DaveWeiYong阅读 3,826评论 0 1
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 12,422评论 2 17
  • 0、对于 HTTP 协议而言,HTML、CSS、JS、JSON 的本质都是什么? 1.对于HTTP协议而言,htm...
    saintkl阅读 3,693评论 0 0
  • 迫不得已和有的陌生人有了一点点交集,被别人立马判断出了:我的内心单纯,我的世界简单,我的社会阅历太少……"社会"这...
    yu菇凉阅读 2,833评论 0 1

友情链接更多精彩内容