zoukankan      html  css  js  c++  java
  • js读取解析JSON类型数据(转)

    谢谢博主,转自http://blog.csdn.net/beyond0851/article/details/9285771

    一、什么是JSON

    JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式,采用完全独立于语言的文本格式,

    是理想的数据交换格式,同时,JSON是 JavaScript 原生格式。

    非常适合于服务器与 JavaScript 的交互

    二、为什么使用JSON而不是XML

    他们都是这样说的:  尽管有许多宣传关于 XML 如何拥有跨平台,跨语言的优势,然而,除非应用于 Web Services,否则,在普通的 Web 应用中,开发者经常为 XML 的解析伤透了脑筋,无论是服务器端生成或处理 XML,还是客户端用 JavaScript 解析 XML,都常常导致复杂的代码,极低的开发效率。实际上,对于大多数 Web 应用来说,他们根本不需要复杂的 XML 来传输数据,XML 的扩展性很少具有优势,许多 AJAX 应用甚至直接返回 HTML 片段来构建动态 Web 页面。和返回 XML 并解析它相比,返回 HTML 片段大大降低了系统的复杂性,但同时缺少了一定的灵活性

    三、如何使用

    下面代码是html代码片段,实现点击按钮解析json格式数据并alert内容

    <input type="button" value="button" onclick="clicks();"/>

    下面是js函数代码:

    var json = {
       contry:{
        area:{
         man:"12万",
         women:"10万"
        }
       }
      };

    //方式一:使用eval解析
      var obj = eval(json);
      alert(obj.constructor);
      alert(obj.contry.area.women);
      //方式二:使用Funtion函数
      var strJSON = "{name:'json name'}";//得到的JSON
      var obj = new Function("return" + strJSON)();//转换后的JSON对象
      alert(obj.name);//json name
      alert(obj.constructor);
      

    //复杂一点的json数组数据的解析
      var value1 = [ 
        {"c01":"1","c02":"2","c03":"3","c04":"4","c05":"5","c06":"6","c07":"7","c08":"8","c09":"9"},
         {"c01":"2","c02":"4","c03":"5","c04":"2","c05":"8","c06":"11","c07":"21","c08":"1","c09":"12"},
        {"c01":"5","c02":"1","c03":"4","c04":"11","c05":"9","c06":"8","c07":"1","c08":"8","c09":"2"}
         ]; 
      var obj1 = eval(value1);
      alert(obj1[0].c01);
     //复杂一点的json的另一种形式
      var value2 = {
         "list":[
          {"password":"1230","username":"coolcooldool"},
          {"password":"thisis2","username":"okokok"}
          ],
         "array":[
          {"password":"1230","username":"coolcooldool"},
          {"password":"thisis2","username":"okokok"}
          ]
         };
      var obj2 = eval(value2);
      alert(obj2.list[0].password);
     }

    4、eval

    1这种形式将使得性能显著降低,因为它必须运行编译器

    2eval函数还减弱了你的应用的安全性,因为它给被求值的文本赋予了太多的权力。就像with语句执行的方式一样,它降低了语言的性能

    3Function构造器是eval的另一种形式,所以它同样也应该被避免使用。

  • 相关阅读:
    高通、猎户机型Android典型bootloader分析
    Ubuntu 14.04 中安装 VMware10 Tools工具
    Linux内核中的GPIO系统之(3):pin controller driver代码分析
    linux内核中的GPIO系统之(2):pin control subsystem
    linux内核中的GPIO系统之(1):软件框架
    WINCE6.0组件选择说明
    看看,这就是微软的“万物互联”系统 window10 IOT
    高通平台 lcd driver 调试小结
    STM8S定时器工作
    开关笔记
  • 原文地址:https://www.cnblogs.com/ningheshutong/p/5412612.html
Copyright © 2011-2022 走看看