XQuery 添加元素和属性


XML 实例文档

我们将在下面的例子中继续使用这个 "bookstore.xml" 文档(与上一节中的 XML 文件相同)。

在您的浏览器中查看 bookstore.xml 文件。


向结果添加元素和属性

正如在前面一节看到的,我们可以在结果中引用输入文件中的元素和属性:

  1. for $x in doc("/example/xml/bookstore.xml")/bookstore/book/title
  2. order by $x
  3. return $x

上面的 XQuery 表达式会在结果中引用 title 元素和 lang 属性,就像这样:

  1. <title lang="en">Everyday Italian</title>
  2. <title lang="en">Harry Potter</title>
  3. <title lang="en">Learning XML</title>
  4. <title lang="en">XQuery Kick Start</title>

以上 XQuery 表达式返回 title 元素的方式和它们在输入文档中被描述的方式的相同的。

现在我们要向结果添加元素和属性!

添加 HTML 元素和文本

现在,我们要向结果添加 HTML 元素。我们会把结果放在一个 HTML 列表中:

  1. <html>
  2. <body>
  3. <h1>Bookstore</h1>
  4. <ul>
  5. {
  6. for $x in doc("/example/xml/bookstore.xml")/bookstore/book
  7. order by $x/title
  8. return
  9. <li>{data($x/title)}. Category: {data($x/@category)}</li>
  10. }
  11. </ul>
  12. </body>
  13. </html>

以上 XQuery 表达式会生成下面的结果:

  1. <html>
  2. <body>
  3. <h1>Bookstore</h1>
  4. <ul>
  5. <li>Everyday Italian. Category: COOKING</li>
  6. <li>Harry Potter. Category: CHILDREN</li>
  7. <li>Learning XML. Category: WEB</li>
  8. <li>XQuery Kick Start. Category: WEB</li>
  9. </ul>
  10. </body>
  11. </html>
向 HTML 元素添加属性

接下来,我们要把 category 属性作为 HTML 列表中的 class 属性来使用:

  1. <html>
  2. <body>
  3. <h1>Bookstore</h1>
  4. <ul>
  5. {
  6. for $x in doc("/example/xml/bookstore.xml")/bookstore/book
  7. order by $x/title
  8. return
  9. <li class="{data($x/@category)}">{data($x/title)}</li>
  10. }
  11. </ul>
  12. </body>
  13. </html>

上面的 XQuery 表达式可生成以下结果:

  1. <html>
  2. <body>
  3. <h1>Bookstore</h1>
  4. <ul>
  5. <li class="COOKING">Everyday Italian</li>
  6. <li class="CHILDREN">Harry Potter</li>
  7. <li class="WEB">Learning XML</li>
  8. <li class="WEB">XQuery Kick Start</li>
  9. </ul>
  10. </body>
  11. </html>