添加链接
link之家
链接快照平台
  • 输入网页链接,自动生成快照
  • 标签化管理网页链接


使用eval()这个内置函数,该方式也适合以普通js方式获取json对象。

var dataObj=eval("("+data+")");
alert(dataObj.root.length);
$.each(dataObj.root,fucntion(idx,item){
if(idx==0){
return true;
alert("name:"+item.name+",value:"+item.value);


为什么eval这里要添加("("+data+")") ?

由于json是以{ }的方式来开始以及结束的,在 eval 中会被当成一个语句块来处理,故必须强制将它转换成一种表达式。

加上圆括号是使eval函数在处理时强制将括号内的表达式(expression)转化为对象而不作为语句(statement)来执行。

若不加外层的括号,eval会将大括号识别为js代码块的开始和结束标记,{ }将会被认为执行了一句空语句。

alert(eval("{}")
结果 undefined

alert(eval("({})")
结果 object[Object]


来看看eval其他用法

eval("alert('xy')");

等价于alert("xy")

var msg = "xy";

eval("alert(msg)");

等价于alert("xy")

eval("x=10;y=20;document.write(x*y)")

结果 200

eval就相当于一个js解析器,很牛哦

原帖地址: http://www.cnblogs.com/myjavawork/archive/2011/03/10/1979279.html

本文转自IT徐胖子的专栏博客51CTO博客,原文链接http://blog.51cto.com/woshixy/959630如需转载请自行联系原作者

woshixuye111

如何使用Request方法发送Post请求、JSON文件介绍、Python中的JSON数据以及获取到的JSON数据的解析。
如何使用Request方法发送Post请求、JSON文件介绍、Python中的JSON数据以及获取到的JSON数据的解析。
【未完美解决】json解析在react componentDidMount请求的数据所导致的问题
json解析在react componentDidMount请求的数据所导致的问题