zoukankan      html  css  js  c++  java
  • 用Js的eval解析JSON中的注意点

    一般解析后台传到前台的json字符串成为js对象有两种方式: 
    1.使用eval()函数
    Js代码  收藏代码
    1. var data="   
    2. {   
    3. root:   
    4. [   
    5. {name:'1',value:'0'},   
    6. {name:'6101',value:'北京市'},   
    7. {name:'6102',value:'天津市'},   
    8. {name:'6103',value:'上海市'},   
    9. {name:'6104',value:'重庆市'},   
    10. {name:'6105',value:'渭南市'},   
    11. {name:'6106',value:'延安市'},   
    12. {name:'6107',value:'汉中市'},   
    13. {name:'6108',value:'榆林市'},   
    14. {name:'6109',value:'安康市'},   
    15. {name:'6110',value:'商洛市'}   
    16. ]  
    17. }";   
    18. var dataObj=eval("("+data+")");//转换为json对象  

    为什么要 eval这里要添加 “("("+data+")");//”呢? 
    原因在于:eval本身的问题。 由于json是以”{}”的方式来开始以及结束的,在JS中,它会被当成一个语句块来处理,所以必须强制性的将它转换成一种表达式。 
        加上圆括号的目的是迫使eval函数在处理JavaScript代码的时候强制将括号内的表达式(expression)转化为对象,而不是作为语 句(statement)来执行。举一个例子,例如对象字面量{},如若不加外层的括号,那么eval会将大括号识别为JavaScript代码块的开始 和结束标记,那么{}将会被认为是执行了一句空语句。所以下面两个执行结果是不同的: 
    Js代码  收藏代码
    1.    
    2. alert(eval("{}"); // return undefined  
    3. alert(eval("({})");// return object[Object]  

    对于这种写法,在JS中,可以到处看到。 
    如: (function()) {}();  做闭包操作时等。 

    2. 使用Function对象来进行返回解析。 
        第二种解析方式就是使用Function对象来完成,它的典型应用就是在JQUERY中的AJAX方法下的success等对于返回数据data的解析: 
    Js代码  收藏代码
    1. var json='{"name":"CJ","age":18}';  
    2.    
    3. data =(new Function("","return "+json))();  
  • 相关阅读:
    MySQL时间函数
    Linux安装php运行环境
    linux 防火墙配置
    CENTOS启动后网卡启动不了
    价值
    浏览器STATUS_INVALID_IMAGE_HASH报错解决方法
    wordpress更改域名最简单的方法
    Connection to 天mysql failed. [08001] Could not create connection to database server. Attempted ,报错处理方法
    centos实现三个节点高可用
    安装nginx1.16.1版本
  • 原文地址:https://www.cnblogs.com/zhangyong123/p/4974554.html
Copyright © 2011-2022 走看看