Latest web development tutorials

XQuery Adicionando elementos e atributos

documentos de instância XML

No exemplo a seguir vamos continuar a utilizar este documento "books.xml" (o mesmo arquivo XML ea seção acima é usada).

Veja o arquivo "books.xml" no seu browser .


Adicionando elementos e atributos os resultados para

Como visto na seção anterior, podemos citar em elementos do arquivo de entrada resultados e atributos:

for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x

expressão XQuery acima elemento title referências e lang atributos no resultado, como este:

<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>

Acima de expressão XQuery retorna os elementos do título da forma e do mesmo modo no documento de entrada encontram-se descritos nos mesmos.

Agora queremos adicionar os resultados de nossos próprios elementos e atributos!

Adicionar elementos HTML e texto

Agora, nós queremos adicionar o elemento de resultados HTML. Nós irá resultar em uma lista 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>

expressão XQuery acima irá gerar os seguintes resultados:

<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>

Adicionando atributos para elementos HTML

Em seguida, devemos atribuir categoria como uma lista de HTML de atributos de classe de usar:

<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>

expressão XQuery acima pode gerar os seguintes resultados:

<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>