javascript XPath 实现【补充】

本文介绍了如何在JavaScript中使用XPath来查找匹配的节点,分别阐述了Mozilla和Chrome浏览器的不同实现方式。在Mozilla中,可以通过Document对象的selectNodes方法结合createExpression和evaluate方法。而在Chrome中,需要使用XMLHttpRequest加载XML文档,然后通过responseXML获取Document对象,再应用XPath表达式进行过滤。

在昨天参照《JavaScript高级程序设计》第15章后,针对XPath做了部分知识汇总后。今天又参看了下w3c标准中的API文档,发现针对XPath的操作亦可使用如下方式:/** * 查找匹配XPath表达式的节点(Mozilla实现selectNodes方法;IE自带该方法) * * @param sXPath * XPath表达式 * @return 节点集合数组 Array<Element> */ Document.prototype.selectNodes = function(sXPath) { var oXPathExpress = this.createExpression(sXPath, null); var oResult = oXPathExpress.evaluate(this, XPathResult.ORDERED_NODE_ITERATOR_TYPE, null); var aNodes = new Array(); if (oResult != null) { var oElement = oResult.iterateNext(); while (oElement) { aNodes.push(oElement); oElement = oResult.iterateNext(); } } return aNodes; };

该方式与原来方式不同的地方在于调要 Document 对象的 createExpression 及 evaluate 方法,而非 XPathEvaluator 对象的 evaluate 方法

相关 Document 对象的 evaluate 方法的说明如下:

createExpression(xpathText,namespaceURLMapper)

参数描述
xpathText表示要编译的 XPath 表达式的字符串。
namespaceURLMapper从一个名字空间前缀映射到一个全称名字空间 URL 的一个函数。如果不需要这样的映射,则为 null。

      
evaluate(xpathText,contextNode,namespaceURLMapper,resultType,result)

参数描述
xpathText表示要计算的 XPath 表达式的字符串。
contextNode文档中,对应要计算的表达式的节点。
namespaceURLMapper

把一个命名空间前缀映射为一个全称命名空间 URL 的函数。

如果不需要这样的映射,就为 null。

resultType

指定了期待作为结果的对象的类型,使用 XPath 转换来强制结果类型。

类型的可能的值是 XPathResult 对象所定义的常量。

result

一个复用的 XPathResult 对象;

如果你要创建一个新的 XPathResult 对象,则为 null。

由于此时的处理都是针对Document的,那么在使用时就无需使用 oXmlDoc.documentElement 而直接使用oXmlDoc.selectNodes(xPath).

同时,昨日的代码无法在chrome浏览器中使用,针对chrome浏览器,读取xml文档需要通过以下方式var xmlhttp = new window.XMLHttpRequest(); xmlhttp.open("GET", "exam1.xml", false); xmlhttp.send(null); oXmlDom = xmlhttp.responseXML;//返回xml Document对象 就此,在chrome浏览器中就可以使用xpath表达式过滤xml文档。(在chrome浏览器中,使用iframe src一个xml文档是会忽略标签的)。有兴趣的可以将其整合的到一个文件中,这里就不在赘述。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值