目录

XQuery 添加元素属性


XML 示例文档

我们将在下面的示例中使用"books.xml" 文档(与前面的章节中相同的 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 表达式返回标题元素的方式与输入文档中描述的方式完全相同。

我们现在想要将我们自己的元素和属性添加到结果中!

添加 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 元素添加属性

接下来,我们要使用类别属性作为 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>