Esempi XPath
- Pagina precedente Operatore XPath
- Pagina successiva Conclusione XPath
In questa sezione, esploreremo alcune basi della sintassi XPath attraverso esempi.
Documento XML di esempio
Utilizzeremo questo documento XML nell'esempio che segue:
"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>
Carica documento XML
Tutti i browser moderni supportano il metodo XMLHttpRequest per caricare documenti XML.
Codice per la maggior parte dei browser moderni:
var xmlhttp=new XMLHttpRequest()
Codice per i browser Microsoft antichi (IE 5 e 6):
var xmlhttp=new ActiveXObject("Microsoft.XMLHTTP")
Seleziona nodi
Sfortunatamente, Internet Explorer e altri gestori XPath si comportano diversamente.
Nel nostro esempio, è inclusa la codifica che è applicabile alla maggior parte dei browser mainstream.
Internet Explorer utilizza il metodo selectNodes() per selezionare i nodi da un documento XML:
xmlDoc.selectNodes(xpath);
Firefox, Chrome, Opera e Safari utilizzano il metodo evaluate() per selezionare i nodi da un documento XML:
xmlDoc.evaluate(xpath, xmlDoc, null, XPathResult.ANY_TYPE, null);
Seleziona tutti i nodi title
Esempio di esempio per tutti i nodi title:
/bookstore/book/title
Seleziona il title del primo book
Esempio seguente: seleziona il nodo title del primo book sotto l'elemento bookstore:
/bookstore/book[1]/title
C'è un problema qui. Gli esempi precedenti producono risultati diversi in IE e altri browser.
Le versioni IE5 e superiori considerano [0] come il primo nodo, mentre secondo lo standard W3C dovrebbe essere [1].
Per risolvere i problemi [0] e [1] in IE5+, è possibile impostare la scelta della lingua per XPath (SelectionLanguage).
Esempio seguente: seleziona il nodo title del primo book sotto l'elemento bookstore:
xml.setProperty("SelectionLanguage","XPath"); xml.selectNodes("/bookstore/book[1]/title");
Seleziona tutte le quote
Esempio seguente: seleziona tutti i testi del nodo price:
/bookstore/book/price/text()
Seleziona i nodi price con prezzo superiore a 35
Esempio seguente: seleziona tutti i nodi price con prezzo superiore a 35:
/bookstore/book[price>35]/price
Seleziona i nodi title con prezzo superiore a 35
Esempio seguente: seleziona tutti i nodi title con prezzo superiore a 35:
/bookstore/book[price>35]/title
- Pagina precedente Operatore XPath
- Pagina successiva Conclusione XPath