1:读取服务器端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节点

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

2.2:.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节点值读取

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

3.2:如果一个节点浏览器不支持,可以使用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的遍历

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

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

4.2: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总结的更多相关文章

  1. JavaScript操作XML

    JavaScript操作XML (一) JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准 ...

  2. XML DOM 遍历Xml文档

    1.xml文档内容: <?xml version="1.0" encoding="utf-8" ?> <bookstore> <b ...

  3. JavaScript操作XML(二)

    上一篇介绍了XML的结构以及节点之间的关系这一篇介绍浏览器内建的XML解析器以及JavaScript是如何加载XML的. 大多数浏览器都有读取和操作 XML 的内建 XML 解析器. 解析器(XML ...

  4. JavaScript操作XML工作记录

    JavaScript操作XML (一) JavaScript操作XML是通过XML DOM来完成的.那么什么是XML DOM呢?XML DOM 是: 用于 XML 的标准对象模型 用于 XML 的标准 ...

  5. ajax-异步JavaScript和XML

    什么是ajax? ajax是异步的javascript和XML ( Asynchronous Javascript And XML ) 优点:节省用户操作时间,提高用户体验.减少数据请求次数. 什么是 ...

  6. C#遍历XML文件动态加载菜单

    通过遍历XML文件动态加载菜单,顺便利用WebBrowser控件实现一个简单的桌面浏览器 效果如下: 代码如下: XMLFile1.xml <?xml version="1.0&quo ...

  7. 18. javacript高级程序设计-JavaScript与XML

    1. JavaScript与XML IE采取了下列方式: l 通过ActiveX对象来支持处理XML,而相同的对象也可以用来构建桌面应用程序 l Windows携带了MSXML库,JavaScript ...

  8. [VBS]遍历XML文档

    一.脚本源码 使用VBS脚本遍历XML文件 Option Explicit '定义常量 '元素 '文本 'CDATA '实体引用 '实体 '处理指令 '注释 '文档类型 '遍历文件 NameList. ...

  9. JavaScript遍历table的行和列

    来源:http://blog.csdn.net/bobwu/article/details/7497412 <HTML> <head> <SCRIPT LANGUAGE= ...

随机推荐

  1. (八十六)使用系统自带的分享框架Social.framework

    使用Social.framework十分简单,能够便捷的分享到主流的社交框架. ①导入主头文件 #import <Social/Social.h> ②以新浪微博为例,首先判断服务是否可用, ...

  2. Mysql group by语句的优化

    默认情况下,MySQL排序所有GROUP BY col1, col2, ....,查询的方法如同在查询中指定ORDER BY  col1, col2, ....如果显式包括一个包含相同的列的ORDER ...

  3. 使用GDAL库中的RPC校正问题

    最近将GDAL库更新至1.11版本之后,发现之前写的RPC像方改正模型校正的结果偏差特别大(更新版本之前结果和PCI处理的结果一致).所以初步判断是GDAL库的bug,经过各个参数修改发现原来是指定的 ...

  4. 【Unity技巧】LOGO闪光效果

    写在前面 本文参考了风宇冲的博文,在按照这篇博文实现LOGO闪光时,发现了一些问题.最严重的就是背景无法透明,看上去背景始终是黑色的:其次就是各个变量的意义不是非常明确,调节起来不方便:而且在闪光条的 ...

  5. UNIX环境高级编程——创建与打开IPC通道

    创建或打开一个IPC对象的三个getXXX函数的第一个参数key是类型为key_t的IPC键,返回值identifier是一个整数标识符.该标识符不同于ftok函数的id参数.对于key值,应用程序有 ...

  6. java反射机制--reflection

    反射,reflection,听其名就像照镜子一样,可以看见自己也可以看见别人的每一部分.在java语言中这是一个很重要的特性.下面是来自sun公司官网关于反射的介绍:    Reflection is ...

  7. 谈谈Ext JS的组件——布局的使用方法续二

    绝对布局(Ext.layout.container.Absolute) 绝对布局让我回想到了使用Foxpro开发的时候,哪时候的界面布局就是这样,通过设置控件的左上角坐标(x,y)和宽度来进行的,因为 ...

  8. Linux0.11中对文本文件进行修改的策略

    现在,假设 hello.txt 是硬盘上已有的一个文件,而且内容为 "hello, world" ,在文件的当前指针设置完毕后,我们来介绍 sys_read , sys_write ...

  9. 9.4、Libgdx简单字符输入

    (官网:www.libgdx.cn) 如果应用需要输入一个字符,比如用户名和密码,可以通过简单的对话框实现. 在桌面中使用一个Swing对话框,提示用户输入字符. 在Android中将会打开一个标准的 ...

  10. Spring MVC中jsessionid所引起的问题 和解决

     转自:http://blog.csdn.net/seakingwy/article/details/1933687 jsessionid所引起的问题在Spring MVC当使用RedirectV ...