JSON.parse(jsonStr)和eval('('+jsonStr+')')

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JSON.parse(jsonStr)和eval('('+jsonStr+')')相关的知识,希望对你有一定的参考价值。

我们先初始化一个json格式的对象:

  var jsonDate = ‘{ "name":"周星驰","age":23 }‘

  var jsonObj = eval( ‘(‘ + jsonDate + ‘)‘ );  // eval();方法

  var jsonObj = JSON.parse( jsonDate );  // JSON.parse(); 方法

然后在控制台调用:

  console.log( jsonObj.name );  // 两种方法都可以正确输入 周星驰

那么问题来了 两种方法有什么区别呢?(下面我们稍微把代码改动一下,蓝色字体为修改部分)

  var jsonDate = ‘{ "name":alert("hello"),"age":23 }‘

  var jsonObj = eval( ‘(‘ + jsonDate + ‘)‘ );  // eval();方法

  console.log( jsonObj.age );  //会先执行“alert”输出“hello”  然后才输出 23

换“JSON.parse();”方法:

  var jsonDate = ‘{ "name":alert("hello"),"age":23 }‘

  var jsonObj = JSON.parse( jsonDate );  // JSON.parse(); 方法

  cosole.log( jsonobj.age )  // 报错  这个错误告诉我们这个字符串是不合法的

小结:“eval();”方法解析的时候不会去判断字符串是否合法,而且json对象中的js方法也会被执行,这是非常危险的;而“JSON.parse();”方法的优点就不用多说了,推荐此方法。

以上是关于JSON.parse(jsonStr)和eval('('+jsonStr+')')的主要内容,如果未能解决你的问题,请参考以下文章

Vue 字符串与Json对象数组之间的转换

js 中 json转换

json对象与字符串互转

JSON.parse()和eval()的区别

JavaScript怎么使用递归将后台json数据转换成树结构

JSON.parse()和eval()的区别