XSLT語法

假設我們有以下示例XML檔:students.xml,它需要轉換為格式良好的HTML文檔。

檔:students.xml 的內容如下 -

<?xml version = "1.0"?>
<class>
   <student rollno = "10010">
      <firstname>Machine</firstname>
      <lastname>Lee</lastname>
      <nickname>Machine</nickname>
      <marks>85</marks>
   </student>
   <student rollno = "10020">
      <firstname>Max</firstname>
      <lastname>Su</lastname>
      <nickname>Maxsu</nickname>
      <marks>95</marks>
   </student>
   <student rollno = "10030">
      <firstname>Yii</firstname>
      <lastname>Bai</lastname>
      <nickname>zaixian</nickname>
      <marks>90</marks>
   </student>
</class>

需要為上面的XML文檔定義一個XSLT樣式表文檔,以滿足以下條件 -

  • 頁面有一個標題。
  • 頁面有一份學生詳細資訊表。
  • 列具有以下標題:Roll No,First Name,Last Name,Nick Name,Marks
  • 表包含學生的詳細資訊。

第1步:創建XSLT文檔

創建一個XSLT文檔以滿足上述要求,將其命名為students.xsl,並將其保存在students.xml所在的同一個目錄位置。

檔:students.xsl -

<?xml version = "1.0" encoding = "UTF-8"?>
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
   <xsl:template match = "/">
      <html>
         <body>
            <h2>Students</h2>
            <table border = "1">
               <tr bgcolor = "#3498db">
                  <th>Roll No</th>
                  <th>First Name</th>
                  <th>Last Name</th>
                  <th>Nick Name</th>
                  <th>Marks</th>
               </tr>
               <!-- for-each處理指令
               查找與XPath運算式匹配的每個元素

               -->
               <xsl:for-each select="class/student">
                  <tr>
                     <td>
                        <!-- value-of處理指令
                        處理與XPath運算式匹配的元素的值

                        -->
                        <xsl:value-of select = "@rollno"/>
                     </td>
                     <td><xsl:value-of select = "firstname"/></td>
                     <td><xsl:value-of select = "lastname"/></td>
                     <td><xsl:value-of select = "nickname"/></td>
                     <td><xsl:value-of select = "marks"/></td>
                  </tr>
               </xsl:for-each>

            </table>
         </body>
      </html>
   </xsl:template>
</xsl:stylesheet>

第2步:將XSLT文檔鏈接到XML文檔

使用以下xml-stylesheet標記更新student.xml文檔。 將href值設置為:students.xsl -

<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
...
</class>

第3步:在流覽器中查看XML文檔

加入樣式檔students.xsl,更新檔:students.xml ,內容如下所示 -

<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
   <student rollno = "10010">
      <firstname>Machine</firstname>
      <lastname>Lee</lastname>
      <nickname>Machine</nickname>
      <marks>85</marks>
   </student>
   <student rollno = "10020">
      <firstname>Max</firstname>
      <lastname>Su</lastname>
      <nickname>Maxsu</nickname>
      <marks>95</marks>
   </student>
   <student rollno = "10030">
      <firstname>Yii</firstname>
      <lastname>Bai</lastname>
      <nickname>zaixian</nickname>
      <marks>90</marks>
   </student>
</class>

在流覽器中打開上面檔:student.xml,效果如下所示 -


上一篇: XSLT簡介 下一篇: XSLT