XPath Exempel

I denna sektion, låt oss lära oss några grundläggande XPath-syntak genom exempel.

XML-exempel

Vi kommer att använda denna XML-dokument i följande exempel:

"books.xml" :

<?xml version="1.0" encoding="ISO-8859-1"?>
<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>

Visa detta "books.xml"-filen i din webbläsare.

Ladda XML-dokument

Alla moderna webbläsare stöder metoden att ladda XML-dokument med XMLHttpRequest.

Kod för de flesta moderna webbläsare:

var xmlhttp=new XMLHttpRequest()

Kod för gamla Microsoft-webbläsare (IE 5 och 6):

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

Välj noder

Tyvärr behandlar Internet Explorer och andra webbläsare XPath på olika sätt.

I vårt exempel innehåller koden som är tillämplig för de flesta vanliga webbläsarna.

Internet Explorer använder selectNodes() metoden för att välja noder från XML-dokument:

xmlDoc.selectNodes(xpath);

Firefox, Chrome, Opera och Safari använder evaluate()-metoden för att välja noder från XML-dokument:

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

Välj alla title

Följande exempel väljer alla title-noder:

/bookstore/book/title

Prova själv

Välj title till den första book-noden

Följande exempel väljer title-noden till den första book-noden under bookstore-elementet:

/bookstore/book[1]/title

Prova själv

Det finns ett problem här. Följande exempel ger olika resultat i IE och andra webbläsare.

IE5 och högre versioner ser [0] som den första noden, medan W3C-standarden skulle vara [1].

För att lösa problemet med [0] och [1] i IE5+ kan du ställa in språkval för XPath (SelectionLanguage).

Följande exempel väljer title-noden till den första book-noden under bookstore-elementet:

xml.setProperty("SelectionLanguage","XPath");
xml.selectNodes("/bookstore/book[1]/title");

Prova själv

Välj alla priser

Följande exempel väljer alla texter i price-noder:

/bookstore/book/price/text()

Prova själv

Välj noder med pris över 35

Följande exempel väljer alla price-noder med pris över 35:

/bookstore/book[price>35]/price

Prova själv

Välj title-noder med pris över 35

Följande exempel väljer alla title-noder med pris över 35:

/bookstore/book[price>35]/title

Prova själv