最新的Web開發教程
 

XQuery的添加元素和屬性


XML實例文檔

我們將使用"books.xml"在下面的例子文件(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表達式返回title元素,因為它們在輸入文檔中描述的完全相同的方式。

現在,我們要添加我們自己的元素和屬性的結果!

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