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