XSLT 轉換
實例研究:如何使用 XSLT 將 XML 轉換為 XHTML。
我們會在下一章對本實例的細節進行解釋。
正確的樣式表宣告
把文件宣告為 XSL 樣式表的根元素是 <xsl:stylesheet> 或 <xsl:transform>。
注意:<xsl:stylesheet> 和 <xsl:transform> 是完全同義的,都可以使用!
根據W3C 的XSLT 標準,宣告XSL 樣式表的正確方法是:
xmlns:xsl="http: //www.w3.org/1999/XSL/Transform">
或:
xmlns :xsl="http://www.w3.org/1999/XSL/Transform">
如需存取XSLT 的元素、屬性以及特性,我們必須在文件頂端宣告XSLT 命名空間。
xmlns:xsl="http://www.w3.org/1999/XSL/Transform" 指向了官方的 W3C XSLT 命名空間。如果您使用此命名空間,則必須包含屬性 version="1.0"。
從一個原始的XML 文件開始
我們現在要把下面這個XML 文件("cdcatalog.xml")轉換為XHTML:
<catalog>
<cd>
<title>Empire Burlesque</title>
<artist>Bob Dylan</artist>
<country>USA</country>
<company>Columbia</company>
<price>10.90</price>
<year>1985</year>
</cd>
.
.
</catalog>
在 Firefox 和 Internet Explorer 中檢視 XML 檔案:開啟 XML 檔案(通常透過點擊某個連結) - XML 文件會以色彩化的程式碼方式來顯示根元素及子元素。點選元素左側的加號(+)或減號(-)可展開或縮小元素的結構。如需查看原始的 XML 原始檔(不含加號和減號),請在瀏覽器選單中選擇"檢視頁面原始碼"或"檢視原始碼"。
在 Netscape 6 中查看 XML 文件:開啟 XML 文件,然後在 XML 文件中按滑鼠右鍵,並選擇"查看頁面原始碼"。 XML 文件會以色彩化的程式碼方式來顯示根元素及子元素。
在 Opera 7 中檢視 XML 文件:開啟 XML 文件,然後在 XML 檔案中按滑鼠右鍵,選擇"框架"/"檢視原始碼"。 XML 文件將顯示為純文字。
檢視"cdcatalog.xml"
建立XSL 樣式表
然後建立一個帶有轉換範本的XSL 樣式表("cdcatalog.xsl"):
<xsl:stylesheet version="1.0"
xmlns :xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:template match="/">
<html>
<body>
<h2>My CD Collection</h2>
<table border="1">
<tr bgcolor="#9acd32">
<th>Title</th>
<th>Artist</th>
</tr>
<xsl:for-each select="catalog/cd">
<tr>
<td><xsl:value-of select="title"/></td>
<td><xsl:value-of select="artist"/></td>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
#</xsl:stylesheet>
檢視"cdcatalog.xsl"
把XSL 樣式表連結到XML 文件
向XML 文件("cdcatalog.xml")新增XSL 樣式表引用:
<?xml-stylesheet type="text/xsl" href=" cdcatalog.xsl"?>
<catalog>
<cd>
<title>Empire Burlesque</title>
<artist>Bob Dylan</artist>
<country>USA</country>
<company>Columbia</company>
<price>10.90</price>
<year>1985</year>
</cd>
.
.
</catalog>
如果您使用的瀏覽器相容XSLT,它會很順利地把您的XML 轉換為XHTML。
查看結果
我們會在下一章對上面的例子中的細節進行解釋。