Форум | Последние учебники веб-разработки
 

Примеры XPath


Давайте попробуем изучить некоторый базовый синтаксис 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()

Код для старых браузеров Microsoft (IE 5 и 6):

var xmlhttp=new ActiveXObject("Microsoft.XMLHTTP")

Выбор узлов

К сожалению, существуют различные способы борьбы с XPath в Internet Explorer и других браузеров.

В наших примерах мы включили код, который должен работать с большинством основных браузеров.

Internet Explorer использует SelectNodes () метод для выбора узлов из документа XML:

xmlDoc.selectNodes(xpath);

Firefox, Chrome, Opera и Safari используют метод оценки () для выбора узлов из документа XML:

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

Выбрать все названия

В следующем примере выбираются все названия узлов:

пример

/bookstore/book/title
Попробуй сам "

Выберите название первой книги

Следующий пример выбирает название первого узла книги под книжный элемент:

пример

/bookstore/book[1]/title
Попробуй сам "

Выбрать все цены

Следующий пример выбирает текст из всех ценовых узлов:

пример

/bookstore/book/price[text()]
Попробуй сам "

Выберите узлы цен с ценой> 35

В следующем примере выбираются все узлы цены с ценой выше 35:

пример

/bookstore/book[price>35]/price
Попробуй сам "

Выберите узлы заголовков с ценой> 35

В следующем примере выбираются все названия узлов с ценой выше 35:

пример

/bookstore/book[price>35]/title
Попробуй сам "