使用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请求的数据所导致的问题