最新的Web開發教程
 

XML和XSLT


還可以使用XSLT轉換XML文檔轉換成HTML。


顯示XML使用XSLT

XSLT (eXtensible Stylesheet Language Transformations)是XML的推薦樣式表語言。

XSLT是遠遠比CSS更複雜。 通過XSLT,您可以添加/刪除元素和屬性,或從輸出文件。 您也可以重新排列和分類元素,進行測試並作出哪些元素隱藏和顯示,以及更多的決策。

XSLT使用XPath查找XML文檔中的信息。


XSLT示例

我們將使用下面的XML文檔:

<?xml version="1.0" encoding="UTF-8"?>
<breakfast_menu>

<food>
<name>Belgian Waffles</name>
<price>$5.95</price>
<description>Two of our famous Belgian Waffles with plenty of real maple syrup</description>
<calories>650</calories>
</food>

<food>
<name>Strawberry Belgian Waffles</name>
<price>$7.95</price>
<description>Light Belgian waffles covered with strawberries and whipped cream</description>
<calories>900</calories>
</food>

<food>
<name>Berry-Berry Belgian Waffles</name>
<price>$8.95</price>
<description>Light Belgian waffles covered with an assortment of fresh berries and whipped cream</description>
<calories>900</calories>
</food>

<food>
<name>French Toast</name>
<price>$4.50</price>
<description>Thick slices made from our homemade sourdough bread</description>
<calories>600</calories>
</food>

<food>
<name>Homestyle Breakfast</name>
<price>$6.95</price>
<description>Two eggs, bacon or sausage, toast, and our ever-popular hash browns</description>
<calories>950</calories>
</food>

</breakfast_menu>

使用XSLT之前它被顯示在瀏覽器將XML轉換為HTML,:

例如XSLT樣式表:

<?xml version="1.0" encoding="UTF-8"?>
<html xsl:version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<body style="font-family:Arial;font-size:12pt;background-color:#EEEEEE">
<xsl:for-each select="breakfast_menu/food">
  <div style="background-color:teal;color:white;padding:4px">
    <span style="font-weight:bold"><xsl:value-of select="name"/> - </span>
    <xsl:value-of select="price"/>
    </div>
  <div style="margin-left:20px;margin-bottom:1em;font-size:10pt">
    <p>
    <xsl:value-of select="description"/>
    <span style="font-style:italic"> (<xsl:value-of select="calories"/> calories per serving)</span>
    </p>
  </div>
</xsl:for-each>
</body>
</html>
轉換XML文檔使用XSLT»

如果您想了解更多有關XSLT,發現我們對我們的XSLT教程網頁