鸿 网 互 联 www.68idc.cn

当前位置 : 服务器租用 > 网站制作教程 > XML/RSS > >

解析JSON时注意的相关问题进行学习

来源:互联网 作者:佚名 时间:2015-03-02 14:45
进行 解析JSON 是基于DOM的,对HTML的DOM熟悉的话,解析XML就没什么困难了。注意:在Firefox中,解析器不会忽略空格,所以元素间的空格,FF一样会认为是一个节点。不过在我们用程序拼接XML的时候,一般不会出现节点间有空格的情况。 如何更好的易于机器解析

进行解析JSON是基于DOM的,对HTML的DOM熟悉的话,解析XML就没什么困难了。注意:在Firefox中,解析器不会忽略空格,所以元素间的空格,FF一样会认为是一个节点。不过在我们用程序拼接XML的时候,一般不会出现节点间有空格的情况。

  • 如何更好的易于机器解析和生成JSON轻量级
  • 更好的解决Javascript解析Json问题
  • 利用JSON插件进行数据交换格式
  • 探索JSON格式封装的使用方法
  • 构建Json插件的相关技巧说明介绍

在根目录下添加一个新的一般处理程序(GetXml.ashx),代码如下:

  1. <input type="button" value="GetXml" onclick="getXml();" /> 

在Default.aspx页面添加以下脚本:

  1. GetXml.ashx 

注意到代码段解析JSON;主要是为了消除IE6和其他浏览器的兼容问题,在其他浏览器下,允许request.responseXML.getElementsByTagName("Person");添加测试按钮:

  1. function getXml() {  
  2.             // 在IE7下测试通过,IE6下必须创建 new ActiveXObject("MSXML2.XMLHTTP.6.0")  
  3.             var request = new XMLHttpRequest();  
  4.  
  5.             request.open('GET', 'GetXml.ashx');  
  6.             request.onreadystatechange = function() {  
  7.                 if (request.readyState == 4 && request.status == 200) {  
  8.                     var xmlDoc = request.responseXML;  
  9.                     var root = xmlDoc.documentElement;  
  10.                     var elements = root.getElementsByTagName("Person");  
  11.                     alert(elements.length); // 2  
  12.                     // elements[0].firstChild 引用到第一个Person节点的Id节点  
  13.                     // elements[0].firstChild.firstChild 引用到Id节点的文本节点  
  14.                     // 因为文本节点是元素节点的第一个子节点  
  15.                     alert(elements[0].firstChild.firstChild.nodeValue); // 1  
  16.                     alert(elements[1].lastChild.firstChild.nodeValue);  // 'n_2'  
  17.                 }  
  18.             }  
  19.             request.send(null);  
  20.         } 

从代码上很容易看出,解析JSON相对直观,在网络中需要传输的字符串也比较少,解析过程中也不需要考虑浏览器兼容问题,但JSON比较适合轻量级的数据交互,XML则比JSON多了一些特性,比如命名空间,还有更多的节点类型。

【责任编辑:苏越 TEL:(010)68476606】

网友评论
<