Esempio XPath
- Pagina precedente Operatore XPath
- Pagina successiva Introduzione a XSLT
In questa sezione, esploreremo alcune basi della sintassi XPath attraverso esempi.
Documento di esempio XML
Utilizzeremo questo documento XML nei seguenti esempi:
"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 browser Microsoft antichi (IE 5 e 6):
var xmlhttp=new ActiveXObject("Microsoft.XMLHTTP")
Seleziona il nodo
Sfortunatamente, Internet Explorer e altri gestiscono XPath in modo diverso.
Nel nostro esempio, è inclusa la codifica che è applicabile a molti 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 title
Esempio seguente: seleziona tutti i nodi title
/bookstore/book/title
Seleziona il title del primo book
Esempio seguente: seleziona il nodo title del primo book sotto bookstore
/bookstore/book[1]/title
C'è un problema qui. L'esempio sopra produce risultati diversi in IE e altri browser.
IE5 e versioni successive considerano [0] come il primo nodo, mentre secondo lo standard W3C dovrebbe essere [1].
Per risolvere il problema [0] e [1] in IE5+, è possibile impostare la scelta di linguaggio (SelectionLanguage) per XPath.
Esempio seguente: seleziona il nodo title del primo book sotto bookstore
xml.setProperty("SelectionLanguage","XPath"); xml.selectNodes("/bookstore/book[1]/title");
Seleziona tutte le tariffe
Esempio seguente: seleziona tutti i testi del nodo price
/bookstore/book/price/text()
Seleziona i nodi price con un prezzo superiore a 35
Esempio seguente che seleziona tutti i nodi price con prezzo superiore a 35:
/bookstore/book[price>35]/price
Selezione dei nodi title con prezzo superiore a 35
Esempio seguente che seleziona tutti i nodi title con prezzo superiore a 35:
/bookstore/book[price>35]/title
- Pagina precedente Operatore XPath
- Pagina successiva Introduzione a XSLT