XPath 实例

创建于 2024-12-03 / 35
字体: [默认] [大] [更大]

让我们通过看一些实例来学习一些基本的XPath语法。


XML实例文档

我们将在下面的实例中使用以下XML文档。

"books.xml":

<?xml version="1.0" encoding="UTF-8"?>

<bookstore>

<book category="cooking">
  <title lang="en">Everyday Italian</title>
  <author>Giada De Laurentiis</author>
  <year>2005</year>
  <price>30.00</price>
</book>

<book category="children">
  <title lang="en">Harry Potter</title>
  <author>J K. Rowling</author>
  <year>2005</year>
  <price>29.99</price>
</book>

<book category="web">
  <title lang="en">XQuery Kick Start</title>
  <author>James McGovern</author>
  <author>Per Bothner</author>
  <author>Kurt Cagle</author>
  <author>James Linn</author>
  <author>Vaidyanathan Nagarajan</author>
  <year>2003</year>
  <price>49.99</price>
</book>

<book category="web">
  <title lang="en">Learning XML</title>
  <author>Erik T. Ray</author>
  <year>2003</year>
  <price>39.95</price>
</book>

</bookstore>

在浏览器中查看 "books.xml" 文件



加载XML文档

所有现代浏览器都支持使用XMLHttpRequest对象加载XML文档。

var xmlhttp = new XMLHttpRequest();

旧浏览器(IE5和IE6)的代码可以在AJAX教程中找到。


选择节点

不幸的是,在不同的浏览器中处理XPath有不同的方法。

Chrome、Firefox、Edge、Opera和Safari使用evaluate()方法选择节点:

xmlDoc.evaluate(xpath, xmlDoc, null, XPathResult.ANY_TYPE,null);

Internet Explorer使用selectNodes()方法选择节点:

xmlDoc.selectNodes(xpath);

在我们的实例中,我们已经包含了应该适用于大多数主流浏览器的代码。


选择所有标题

以下实例选择所有标题节点:

实例

/bookstore/book/title 尝试一下 »

选择第一本书的标题

以下实例选择bookstore元素下第一个book节点的标题:

实例

/bookstore/book[1]/title 尝试一下 »

选择所有价格

以下实例从所有价格节点中选择文本:

实例

/bookstore/book/price[text()] 尝试一下 »

选择价格>35的价格节点

以下实例选择价格高于35的所有价格节点:

实例

/bookstore/book[price>35]/price 尝试一下 »

选择价格>35的标题节点

以下实例选择价格高于35的所有标题节点:

实例

/bookstore/book[price>35]/title 尝试一下 »

0 人点赞过