A-A+

JavaScript遍历XML各种方法总结

2016年01月21日 web前端设计 暂无评论 阅读 6 views 次

本文章总结了在javascript中遍历XML各种方法总结,有需要了解的同学可参考本文章。

遍历节点树:

您经常需要循环 XML 文档,比如:当你需要提取每个元素的值时。

这个过程叫作“遍历节点树”

读取服务器端xml(注意不同浏览器版本的区别),使用XML可以增强系统的扩展性,只用修改XML就可以实现增加减少功能的目的,代码如下:

  1. function loadXMLDoc1(dname){  
  2.     if (window.XMLHttpRequest){  
  3.         xhttp=new XMLHttpRequest();  
  4.     }else{  
  5.         xhttp=new ActiveXObject("Microsoft.XMLHTTP");  
  6.     }  
  7.     xhttp.open("GET",dname,false);  
  8.     xhttp.send("");  
  9.     return xhttp.responseXML;  
  10. }  

2:遍历XML节点

getElementsByTagName() 方法可以在取得一个节点后继续调用获得子节点,并且返回的是一个数组(只有一个节点时也要加上[0])

.childNodes[0].nodeValue) 取得一个节点的值的办法,节点的值也是节点(文本节点),代码如下:

  1. function test() {  
  2.     var xml=loadXMLDoc1("book.xml");  
  3.     var bookss=xml.getElementsByTagName("book");  
  4.     for(var i=0;i<bookss.length;i++) {  
  5.         document.write(bookss[i].getElementsByTagName("title")[0].childNodes[0].nodeValue);  
  6.         document.write("</br>");  
  7.         document.write(bookss[i].getElementsByTagName("author")[0].childNodes[0].nodeValue);  
  8.         document.write("</br>");  
  9.         document.write(bookss[i].getElementsByTagName("year")[0].childNodes[0].nodeValue);  
  10.         document.write("</br>");  
  11.         document.write(bookss[i].getElementsByTagName("price")[0].childNodes[0].nodeValue);  
  12.         document.write("</br>");  
  13.     }  
  14. }  

3:CDATA节点值读取

如果一个XML节点中是CDATA,读取时不同浏览器的方法不同,在IE下nodeValue可以正常获取到值,在FF和chrome下通过wholeText读取。

如果一个节点浏览器不支持,可以使用if进行判断,代码如下:

  1. function testCDATA() {  
  2.     var xml=loadXMLDoc1("ceshi.xml");  
  3.     var HightChartsOpinions=xml.getElementsByTagName("HightChartsOpinions");  
  4.     for(var i=0;i<HightChartsOpinions.length;i++) {  
  5.         var wholeTextData=HightChartsOpinions[i].childNodes[0].wholeText;  
  6.         var text=wholeTextData?wholeTextData:HightChartsOpinions[i].childNodes[0].nodeValue  
  7.         document.write(text);  
  8.         document.write("</br>");  
  9.     }  
  10.     return false;  
  11. }  

4:通过XPATH进行XML的遍历

XPATH可以非常强大的进行XML节点的过滤,以下的链接中包含了常用的xpath用法。

http://www.w3school.com.cn/xpath/xpath_examples.asp

xpath读取xml 不同浏览器也有不同的方法实现,这里使用回调函数处理返回节点,代码如下:

  1. function xpath() {  
  2.     var xmlFilePath="book.xml";  
  3.     var xpath="/bookstore/book[price>45]";  
  4.     var callback=function(element) {  
  5.         document.write(element.getElementsByTagName("title")[0].childNodes[0].nodeValue);  
  6.         document.write("</br>");  
  7.         document.write(element.getElementsByTagName("author")[0].childNodes[0].nodeValue);  
  8.         document.write("</br>");  
  9.         document.write(element.getElementsByTagName("year")[0].childNodes[0].nodeValue);  
  10.         document.write("</br>");  
  11.         document.write(element.getElementsByTagName("price")[0].childNodes[0].nodeValue);  
  12.         document.write("</br>");  
  13.     };  
  14.     handlerXML(xmlFilePath,xpath,callback);  
  15. }  
  16.    
  17. function handlerXML(xmlFilePath,xpath,callback) {  
  18.     var xml=loadXMLDoc1(xmlFilePath);  
  19.     var action;  
  20.     if (window.ActiveXObject)  
  21.     {  
  22.         var nodes=xml.selectNodes(xpath);  
  23.         for (i=0;i<nodes.length;i++){  
  24.             callback(nodes[i]);  
  25.         }  
  26.     }else if (document.implementation && document.implementation.createDocument){  
  27.         var nodes=xml.evaluate(xpath, xml, null, XPathResult.ANY_TYPE, null);  
  28.         var result=nodes.iterateNext();  
  29.         while (result){  
  30.             callback(result);  
  31.             result=nodes.iterateNext();  
  32.         }  
  33.     }  
  34. }  

JavaScript 解析和生成 XML

用 JS 解析和生成 XML 一般都是使用 DOMDocument 这个对象, 下面简单的列出其属性和方法:

属性:

Attributes 存储节点的属性列表 (只读)

childNodes 存储节点的子节点列表 (只读)

dataType 返回此节点的数据类型

Definition 以DTD或XML模式给出的节点的定义 (只读)

Doctype 指定文档类型节点 (只读)

documentElement 返回文档的根元素 (可读写)

firstChild 返回当前节点的第一个子节点 (只读)

Implementation 返回XMLDOMImplementation对象

lastChild 返回当前节点最后一个子节点 (只读)

nextSibling 返回当前节点的下一个兄弟节点(只读)

nodeName 返回节点的名字 (只读)

nodeType 返回节点的类型 (只读)

nodeTypedValue 存储节点值 (可读写)

nodeValue 返回节点的文本 (可读写)

ownerDocument 返回包含此节点的根文档 (只读)

parentNode 返回父节点 (只读)

Parsed 返回此节点及其子节点是否已经被解析 (只读)

Prefix 返回名称空间前缀 (只读)

preserveWhiteSpace 指定是否保留空白 (可读写)

previousSibling 返回此节点的前一个兄弟节点 (只读)

Text 返回此节点及其后代的文本内容 (可读写)

url 返回最近载入的XML文档的URL (只读)

Xml 返回节点及其后代的XML表示 (只读)

方法:

appendChild 为当前节点添加一个新的子节点,放在最后的子节点后

cloneNode 返回当前节点的拷贝

createAttribute 创建新的属性

createCDATASection 创建包括给定数据的CDATA段

createComment 创建一个注释节点

createDocumentFragment 创建DocumentFragment对象

createElement 创建一个元素节点

createEntityReference 创建EntityReference对象

createNode 创建给定类型,名字和命名空间的节点

createPorcessingInstruction 创建操作指令节点

createTextNode 创建包括给定数据的文本节点

getElementsByTagName 返回指定名字的元素集合

hasChildNodes 返回当前节点是否有子节点

insertBefore 在指定节点前插入子节点

Load 导入指定位置的XML文档

loadXML 导入指定字符串的XML文档

removeChild 从子结点列表中删除指定的子节点

replaceChild 从子节点列表中替换指定的子节点

Save 把XML文件存到指定节点

selectNodes 对节点进行指定的匹配,并返回匹配节点列表

selectSingleNode 对节点进行指定的匹配,并返回第一个匹配节点

transformNode 使用指定的样式表对节点及其后代进行转换

transformNodeToObject 使用指定的样式表将节点及其后代转换为对象

标签:

给我留言