JSON.parse 与 eval() 对于解析json的问题
1.eval()与JSOn.parse的不同
eval()
var c = 1; //全局变量
var jsonstr1 = '{"name":"a","company":"b","value":++c}';
var json1 = eval('(' + jsonstr1 + ')');
console.log(json1.value);

c是全局变量为1,但是经过eval的解析,全局变量变成了2!(这样的写法是危险的)
JSON.parse
var c = 1; //全局变量
var jsonstr1 = '{"name":"a","company":"b","value":++c}';
var json2 = JSON.parse(jsonstr1);
console.log(json2.value);
IE下报错:
谷歌下报错:
而JSON.parse则会报错。
2.在++c中加上双引号则就可以,因为它变成字符串了。
var c = 1; //全局变量
var jsonstr1 = '{"name":"a","company":"b","value":“++c”}';
var json2 = JSON.parse(jsonstr1);
console.log(json2.value);
结果:
3.我想很多人在纠结双引号的问题,这里我们就来集中测试下。
a:JSON.parse
var c = 1; //全局变量
var date = new Date();
console.log(date.toLocaleDateString());
//var jsonstr1 = '{"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}';//全无双引号 //var json1 = JSON.parse(jsonstr1);
var json2 = 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()
var c = 1; //全局变量
var date = new Date();
console.log(date.toLocaleDateString()); var jsonstr1 = '{"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}';//全无双引号 var json1 = 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()解析的时候要加上括号?
我们先看看不加括号会怎么样:
var c = 1; //全局变量
var date = new Date();
console.log(date.toLocaleDateString()); var jsonstr1 = '{"name":"a","company":"b","value":"++c"}';//键,值都有双引号 var json1 = eval(jsonstr1); console.log(json1+" "+json1.value );
结果:
这里不加就出错了。
那是因为eval()相当于一个执行环境,当你不加括号的时候,jsonstr1会被认为是一条复合语句。运行的时候就会逐个字符的解析。
但是加上括号的时候,jsonstr1就当做一个表达式去运算。从括号开始就被当做了对象进行识别。
5.然后你又会想到,那这个括号为什么要加“()”,不能加“{}”么?
答案是:当然能加“{}”,只不过就会报错而已~。— —!
这时候你要明吧json的格式是什么!
{"name":"a","company":"b"} 这就是标准形式。
JSON.parse 与 eval() 对于解析json的问题的更多相关文章
- JSON.parse与eval
文章:JSON.parse 与 eval() 对于解析json的问题 json的标准格式:{"name":"jobs"} 名字和值都必须用双引号引起来.
- JSON.parse和eval的区别
JSON.parse和eval的区别 JSON(JavaScript Object Notation)是一种轻量级的数据格式,采用完全独立于语言的文本格式,是理想的数据交换格式.同时,JSON是Jav ...
- JSON.parse与eval的区别
JSON.parse与eval和能将一个字符串解析成一个JSON对象,但还是有挺大区别. 测试代码 var A = "{ a: 1 , b : 'hello' }"; var B ...
- [转]javascript eval函数解析json数据时为什加上圆括号eval("("+data+")")
javascript eval函数解析json数据时为什么 加上圆括号?为什么要 eval这里要添加 “("("+data+")");//”呢? 原因在于: ...
- JSON.stringify()、JSON.parse()和eval(string)
1.JSON.stringify()用于从一个对象解析出字符串,eg: var obj = {"name":"奔跑的蜗牛","age":&q ...
- 用JSON.parse和eval出现的问题
json格式非常受欢迎,而解析json的方式通常用JSON.parse()但是eval()方法也可以解析,这两者之间有什么区别呢? JSON.parse()之可以解析json格式的数据,并且会对要解析 ...
- Js中JSON.stringify()与JSON.parse()与eval()详解及使用案例
JSON(JavaScript Object Notation)是一种轻量级的数据交换格式.因为采用独立于语言的文本格式,也使用了类似于C语言家族的习惯,拥有了这些特性使使JSON称为理想的数据交换语 ...
- JSON.parse()和eval()的区别
json格式非常受欢迎,而解析json的方式通常用JSON.parse()但是eval()方法也可以解析,这两者之间有什么区别呢? JSON.parse()之可以解析json格式的数据,并且会对要解析 ...
- JS中JSON.parse和eval的异同
1.相同点 JSON.parse和eval函数都可将一段json字符串转换为json对象,如: var json = '{"intro":[{"name":&q ...
随机推荐
- 平台之大势何人能挡? 带着你的Net飞奔吧!
镇楼图: 跨平台系列: Linux基础 1.Linux基础学习 By dnt http://www.cnblogs.com/dunitian/p/4822807.html 环境配置 1.Hyper-v ...
- 哪种缓存效果高?开源一个简单的缓存组件j2cache
背景 现在的web系统已经越来越多的应用缓存技术,而且缓存技术确实是能实足的增强系统性能的.我在项目中也开始接触一些缓存的需求. 开始简单的就用jvm(java托管内存)来做缓存,这样对于单个应用服务 ...
- URL安全的Base64编码
Base64编码可用于在HTTP环境下传递较长的标识信息.在其他应用程序中,也常常需要把二进制数据编码为适合放在URL(包括隐藏表单域)中的形式.此时,采用Base64编码不仅比较简短,同时也具有不可 ...
- C语言 · 整数平均值
编写函数,求包含n个元素的整数数组中元素的平均值.要求在函数内部使用指针操纵数组元素,其中n个整数从键盘输入,输出为其平均值. 样例输入: (输入格式说明:5为输入数据的个数,3 4 0 0 2 是以 ...
- 一步一步教你用CSS画爱心
今天小颖给大家分享一个用CSS画的爱心,底下有代码和制作过程,希望对大家有所帮助. 第一步: 先画一个正方形.如图: <!DOCTYPE html> <html> <he ...
- MAVEN学习-第一个Maven项目的构建
MAVEN安装成功之后就可以进行项目的构建和管理了: 为什么要用maven进行项目的构建和管理? 对于初学者来说一个最直接的也是最容易里的优点在于JAR包的管理,相对于以前开发一个项目的时候我们需要用 ...
- Linux常用指令指南,终端装逼利器
最近搞了台Macbook Pro,就学习了一下Linux命令,在网上查了些资料,看了本书叫<快乐的 Linux 命令行>,里面涉及到了各个方面的命令. 在此将常用的整理出来,以备将来使用. ...
- winform 窗体圆角设计
网上看到的很多winform窗体圆角设计代码都比较累赘,这里分享一个少量代码就可以实现的圆角.主要运用了System.Drawing.Drawing2D. 效果图 代码如下. private void ...
- 微服务与Docker介绍
什么是微服务 微服务应用的一个最大的优点是,它们往往比传统的应用程序更有效地利用计算资源.这是因为它们通过扩展组件来处理功能瓶颈问题.这样一来,开发人员只需要为额外的组件部署计算资源,而不需要部署一个 ...
- Eclipse出现"Running Android Lint has encountered a problem"解决方案
安装eclipse for android 时候的错误记录,转载自:http://blog.csdn.net/chenyufeng1991/article/details/47442555 (1)打开 ...