当前位置:编程学习 > JS >>

JavaScript遍历XML各种方法总结

遍历节点树
您经常需要循环 XML 文档,比如:当你需要提取每个元素的值时。
这个过程叫作“遍历节点树”


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

 代码如下 复制代码
function loadXMLDoc1(dname){
    if (window.XMLHttpRequest){
        xhttp=new XMLHttpRequest();
    }else{
        xhttp=new ActiveXObject("Microsoft.XMLHTTP");
    }
    xhttp.open("GET",dname,false);
    xhttp.send("");
    return xhttp.responseXML;
}
 

2:遍历XML节点
getElementsByTagName() 方法可以在取得一个节点后继续调用获得子节点,并且返回的是一个数组(只有一个节点时也要加上[0])
.childNodes[0].nodeValue) 取得一个节点的值的办法,节点的值也是节点(文本节点)

 代码如下 复制代码
function test() {
    var xml=loadXMLDoc1("book.xml");
    var bookss=xml.getElementsByTagName("book");
    for(var i=0;i<bookss.length;i++) {
        document.write(bookss[i].getElementsByTagName("title")[0].childNodes[0].nodeValue);
        document.write("</br>");
        document.write(bookss[i].getElementsByTagName("author")[0].childNodes[0].nodeValue);
        document.write("</br>");
        document.write(bookss[i].getElementsByTagName("year")[0].childNodes[0].nodeValue);
        document.write("</br>");
        document.write(bookss[i].getElementsByTagName("price")[0].childNodes[0].nodeValue);
        document.write("</br>");
    }
}

 
3:CDATA节点值读取
如果一个XML节点中是CDATA,读取时不同浏览器的方法不同,在IE下nodeValue可以正常获取到值,在FF和chrome下通过wholeText读取。
如果一个节点浏览器不支持,可以使用if进行判断。

 代码如下 复制代码
function testCDATA() {
    var xml=loadXMLDoc1("ceshi.xml");
    var HightChartsOpinions=xml.getElementsByTagName("HightChartsOpinions");
    for(var i=0;i<HightChartsOpinions.length;i++) {
        var wholeTextData=HightChartsOpinions[i].childNodes[0].wholeText;
        var text=wholeTextData?wholeTextData:HightChartsOpinions[i].childNodes[0].nodeValue
        document.write(text);
        document.write("</br>");
    }
    return false;
}
 


4: 通过XPATH进行XML的遍历
XPATH可以非常强大的进行XML节点的过滤,以下的链接中包含了常用的xpath用法。
http://www.w3school.com.cn/xpath/xpath_examples.asp
xpath读取xml 不同浏览器也有不同的方法实现,这里使用回调函数处理返回节点。

 代码如下 复制代码

function xpath() {
    var xmlFilePath="book.xml";
    var xpath="/bookstore/book[price>45]";
    var callback=function(element) {
        document.write(element.getElementsByTagName("title")[0].childNodes[0].nodeValue);
        document.write("</br>");
        document.write(element.getElementsByTagName("author")[0].childNodes[0].nodeValue);
        document.write("</br>");
        document.write(element.getElementsByTagName("year")[0].childNodes[0].nodeValue);
        document.write("</br>");
        document.write(element.getElementsByTagName("price")[0].childNodes[0].nodeValue);
        document.write("</br>");
    };
    handlerXML(xmlFilePath,xpath,callback);
}
 
function handlerXML(xmlFilePath,xpath,callback) {
    var xml=loadXMLDoc1(xmlFilePath);
    var action;
    if (window.ActiveXObject)
    {
        var nodes=xml.selectNodes(xpath);
        for (i=0;i<nodes.length;i++){
            callback(nodes[i]);
        }
    }else if (document.implementation && document.implementation.createDocument){
        var nodes=xml.evaluate(xpath, xml, null, XPathResult.ANY_TYPE, null);
        var result=nodes.iterateNext();
        while (result){
            callback(result);
            result=nodes.iterateNext();
        }
    }
}

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  使用指定的样式表将节点及其后代转换为对象

补充:网页制作,js教程 
CopyRight © 2012 站长网 编程知识问答 www.zzzyk.com All Rights Reserved
部份技术文章来自网络,