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>Yiibai</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>Yiibai</nickname> 
      <marks>90</marks> 
   </student> 
</class>

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

XSLT語法