javascript 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文档是会忽略标签的)。有兴趣的可以将其整合的到一个文件中,这里就不在赘述。

你可能感兴趣的:(javascript XPath 实现【补充】)