XQuery 新增元素 和屬性
XML 實例文件
我們將在下面的範例中繼續使用這個 "books.xml" 文件(和上面的章節所使用的 XML 檔案相同)。
在您的瀏覽器中查看 "books.xml" 檔案。
在結果中加入元素和屬性
如同在前面一節所看到的,我們可以在結果中引用輸入檔案中的元素和屬性:
#for $x in doc("books.xml")/bookstore/book/title
order by $x
return $x
order by $x
return $x
<title lang="en">Everyday Italian</title>
以上XQuery 表達式傳回title 元素的方式和它們在輸入文件中被描述的方式的相同的。 現在我們要為結果添加我們自己的元素和屬性! 新增 HTML 元素和文字現在,我們要為結果新增 HTML 元素。我們會把結果放在一個HTML 清單中:<title lang="en" >Harry Potter</title>
<title lang="en">Learning XML</title>
<title lang="en">XQuery Kick Start</title>
<title lang="en">Learning XML</title>
<title lang="en">XQuery Kick Start</title>
<html>
以上XQuery 表達式會產生下面的結果:<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>
<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>
<html>
<body>
< ;h1>Bookstore</h1>
<ul>
<li>Everyday Italian. Category: COOKING</li>
<li>Harry Potter. Category: CHILDREN<
<li>Harry Potter. Category: CHILDREN< li>
<li>Learning XML. Category: WEB</li>
<li>XQuery Kick Start. Category: WEB</li>
</ul>
</body>
</html>
< ;h1>Bookstore</h1>
<ul>
<li>Everyday Italian. Category: COOKING</li>
<li>Harry Potter. Category: CHILDREN<
<li>Harry Potter. Category: CHILDREN< li>
<li>Learning XML. Category: WEB</li>
<li>XQuery Kick Start. Category: WEB</li>
</ul>
</body>
</html>
在HTML 元素上加入屬性
接下來,我們要把category 屬性當作HTML 清單中的class 屬性來使用:
##<html>
上面的XQuery 表達式可產生下列結果:< 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>
<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>
<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>
<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>