tutoriais mais recente desenvolvimento web
 

XQuery Adicionando elementos e atributos


O Exemplo documento XML

Nós vamos usar o "books.xml" documento nos exemplos abaixo (same XML file as in the previous chapters) .

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


Adicionando elementos e atributos ao Resultado

Como vimos no capítulo anterior, podemos incluir elementos e atributos do documento de entrada ("books.xml) no resultado:

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

A expressão Xquery acima irá incluir tanto o elemento título e o lang atributo 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>

A expressão Xquery acima retorna os elementos do título da mesma maneira como eles estão descritos no documento de entrada.

Agora queremos adicionar nossos próprios elementos e atributos para o resultado!

Adicionar elementos e texto HTML

Agora, queremos adicionar alguns elementos HTML para o resultado. Vamos colocar o resultado em uma lista HTML - juntamente com algum texto:

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

A expressão Xquery acima irá gerar o seguinte resultado:

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

Adicionar atributos para elementos HTML

Em seguida, queremos usar a category atributo como um atributo de classe na lista de 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>

A expressão Xquery acima irá gerar o seguinte resultado:

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