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

XQuery Добавление элементов и атрибутов


Пример 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>