XSLT ไวยากรณ์
สมมติว่าเรามีไฟล์ XML ตัวอย่างต่อไปนี้ students.xml ซึ่งจำเป็นต้องเปลี่ยนเป็นเอกสาร HTML ที่มีรูปแบบดี
students.xml
<?xml version = "1.0"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>
เราจำเป็นต้องกำหนดเอกสารสไตล์ชีต XSLT สำหรับเอกสาร XML ด้านบนเพื่อให้เป็นไปตามเกณฑ์ต่อไปนี้ -
หน้าควรมีชื่อเรื่อง Students.
หน้าควรมีตารางรายละเอียดนักเรียน
คอลัมน์ควรมีส่วนหัวต่อไปนี้: 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 declaration with xsl namespace:
Namespace tells the xlst processor about which
element is to be processed and which is used for output purpose only
-->
<xsl:stylesheet version = "1.0"
xmlns:xsl = "http://www.w3.org/1999/XSL/Transform">
<!-- xsl template declaration:
template tells the xlst processor about the section of xml
document which is to be formatted. It takes an XPath expression.
In our case, it is matching document root element and will
tell processor to process the entire document with this template.
-->
<xsl:template match = "/">
<!-- HTML tags
Used for formatting purpose. Processor will skip them and browser
will simply render them.
-->
<html>
<body>
<h2>Students</h2>
<table border = "1">
<tr bgcolor = "#9acd32">
<th>Roll No</th>
<th>First Name</th>
<th>Last Name</th>
<th>Nick Name</th>
<th>Marks</th>
</tr>
<!-- for-each processing instruction
Looks for each element matching the XPath expression
-->
<xsl:for-each select="class/student">
<tr>
<td>
<!-- value-of processing instruction
process the value of the element matching the XPath expression
-->
<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
อัปเดตเอกสาร student.xml ด้วยแท็ก xml-stylesheet ต่อไปนี้ ตั้งค่า href เป็น students.xsl
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
...
</class>
ขั้นตอนที่ 3: ดูเอกสาร XML ใน Internet Explorer
students.xml
<?xml version = "1.0"?>
<?xml-stylesheet type = "text/xsl" href = "students.xsl"?>
<class>
<student rollno = "393">
<firstname>Dinkar</firstname>
<lastname>Kad</lastname>
<nickname>Dinkar</nickname>
<marks>85</marks>
</student>
<student rollno = "493">
<firstname>Vaneet</firstname>
<lastname>Gupta</lastname>
<nickname>Vinni</nickname>
<marks>95</marks>
</student>
<student rollno = "593">
<firstname>Jasvir</firstname>
<lastname>Singh</lastname>
<nickname>Jazz</nickname>
<marks>90</marks>
</student>
</class>