天天看點

XQuery 添加元素 和屬性

我們将在下面的例子中繼續使用這個 "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>

<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 表達式會生成下面的結果:

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

接下來,我們要把 category 屬性作為 HTML 清單中的 class 屬性來使用:

return <li class="{data($x/@category)}">{data($x/title)}</li>

上面的 XQuery 表達式可生成以下結果:

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