XQuery 新增元素和屬性
XML 示例文件
我們在下面的示例中將使用“books.xml”文件(與前幾章相同)。
向結果中新增元素和屬性
正如我們在前一章中看到的,我們可以將輸入文件(“books.xml)中的元素和屬性包含在結果中。
for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x
上面的 XQuery 表示式將包含 title 元素和 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>書店</h1>
<ul>
{
for $x in doc("books.xml")/bookstore/book
order by $x/title
return <li>{data($x/title)}. 類別: {data($x/@category)}</li>
}
</ul>
</body>
</html>
上面的 XQuery 表示式將生成以下結果:
<html>
<body>
<h1>書店</h1>
<ul>
<li>Everyday Italian. 類別: COOKING</li>
<li>Harry Potter. 類別: CHILDREN</li>
<li>Learning XML. 類別: WEB</li>
<li>XQuery Kick Start. 類別: WEB</li>
</ul>
</body>
</html>
為 HTML 元素新增屬性
接下來,我們要將 category 屬性用作 HTML 列表中的 class 屬性。
<html>
<body>
<h1>書店</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>書店</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>