Пример XML документа
Мы будем использовать "books.xml" документ в приведенных ниже примерах (same XML file as in the previous chapters) тот (same XML file as in the previous chapters) , (same XML file as in the previous chapters) и (same XML file as in the previous chapters) .
Просмотр "books.xml" файл в вашем браузере .
Добавление элементов и атрибутов к результату
Как мы уже видели в предыдущей главе, мы можем включать в себя элементы и атрибуты из входного документа ("books.xml) в результате:
for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x
Выражение XQuery выше , будет включать в себя как элемент заголовка и lang атрибут в результате, как это:
<title lang="en">Everyday Italian</title>
<title lang="en">Harry Potter</title>
<title lang="en">Learning XML</title>
<title lang="en">XQuery Kick Start</title>
Выражение XQuery выше возвращает заголовок элементы точно так же, как они описаны во входном документе.
Теперь мы хотим, чтобы добавить свои собственные элементы и атрибуты результата!
Добавить HTML элементы и текст
Теперь мы хотим, чтобы добавить некоторые HTML элементы результата. Мы поместим результат в списке HTML - вместе с текстом:
<html>
<body>
<h1>Bookstore</h1>
<ul>
{
for $x in doc("books.xml")/bookstore/book
order by $x/title
return <li>{data($x/title)}. Category: {data($x/@category)}</li>
}
</ul>
</body>
</html>
Выражение XQuery выше будет генерировать следующий результат:
<html>
<body>
<h1>Bookstore</h1>
<ul>
<li>Everyday Italian. Category: COOKING</li>
<li>Harry Potter. Category: CHILDREN</li>
<li>Learning XML. Category: WEB</li>
<li>XQuery Kick Start. Category: WEB</li>
</ul>
</body>
</html>
Добавление атрибутов в HTML-элементы
Далее, мы хотим использовать category атрибут в качестве атрибута класса в списке HTML:
<html>
<body>
<h1>Bookstore</h1>
<ul>
{
for $x in doc("books.xml")/bookstore/book
order by $x/title
return <li class="{data($x/@category)}">{data($x/title)}</li>
}
</ul>
</body>
</html>
Выражение XQuery выше будет генерировать следующий результат:
<html>
<body>
<h1>Bookstore</h1>
<ul>
<li class="COOKING">Everyday Italian</li>
<li class="CHILDREN">Harry Potter</li>
<li class="WEB">Learning XML</li>
<li class="WEB">XQuery Kick Start</li>
</ul>
</body>
</html>