XQuery 添加元素 和 属性
XML 示例文档
我们将在下面的示例中使用 "books.xml" 文档(与前几章中的 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>