XSLT - ทางเซิร์ฟเวอร์

เนื่องจากไม่ทุกเบราเซอร์ที่สนับสนุน XSLT แนวทางแก้ปัญหาอีกอันหนึ่งคือทำการเปลี่ยนแปลง XML ไปเป็น XHTML บนเซิร์ฟเวอร์

แนวทางแก้ปัญหาที่เคลื่อนไหวทางเบราเซอร์

ในบทเรียนก่อนหน้านี้ เราได้เล่าว่าจะใช้ XSLT ในเบราเซอร์เพื่อทำการเปลี่ยนแปลง XML ไปเป็น XHTML รวมถึงการสร้าง JavaScript ที่ใช้ XML พาเซอร์เพื่อทำการเปลี่ยนแปลง แต่แนวทางแก้ปัญหานี้ไม่สามารถทำงานได้บนเบราเซอร์ที่ไม่มี XML พาเซอร์ ในการที่ข้อมูล XML สามารถใช้งานได้บนเบราเซอร์ทุกชนิด เราต้องทำการเปลี่ยนแปลง XML ไฟล์บนเซิร์ฟเวอร์แล้วส่งไปที่เบราเซอร์ในรูปแบบ XHMTL

นี่คือข้อยอดของ XSLT อีกอันหนึ่ง XSLT มีเป้าหมายหนึ่งในการออกแบบเพื่อที่จะทำให้มีความเป็นไปได้ที่จะเปลี่ยนแปลงรูปแบบของข้อมูลบนเซิร์ฟเวอร์จากรูปแบบหนึ่งไปยังรูปแบบอื่น และส่งข้อมูลที่สามารถอ่านได้โดยเซิร์ฟเวอร์ทุกชนิดของเบราเซอร์

XML ไฟล์และ XSL ไฟล์

โปรดดู XML เอกสารที่ได้แสดงในบทเรียนก่อนหน้านี้:

<?xml version="1.0" encoding="ISO-8859-1"?>
<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>

ตรวจสอบไฟล์ XML นี้.

และตารางสไตล์ XSL ที่มีติดตาม:

<?xml version="1.0" encoding="ISO-8859-1"?>
<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 align="left">Title</th> 
        <th align="left">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>

ตรวจสอบไฟล์ XSL นี้.

โปรดระวังว่า ไฟล์ XML นี้ไม่มีการอ้างอิงไฟล์ XSL

ความสำคัญ:ประโยคดังกล่าวบอกว่า ไฟล์ XML สามารถใช้ตารางสไตล์ XSL หลายตารางเพื่อการเปลี่ยนแบบได้

การเปลี่ยนแบบ XML ในเซิร์ฟเวอร์เป็น XHTML

นี่คือรหัสตัวแทนที่ทำการเปลี่ยนแบบ XML ในเซิร์ฟเวอร์เป็น XHTML:

<%
Load XML
set xml = Server.CreateObject("Microsoft.XMLDOM")
xml.async = false
xml.load(Server.MapPath("cdcatalog.xml"))
'Load XSL
set xsl = Server.CreateObject("Microsoft.XMLDOM")
xsl.async = false
xsl.load(Server.MapPath("cdcatalog.xsl"))
'Transform file
Response.Write(xml.transformNode(xsl))
%>

คำเตือน:หากคุณไม่ทราบว่าจะเขียน ASP คุณสามารถเรียนรู้จากเราในเล่มของเราที่ชื่อคู่มือ ASP>

รหัสที่ 1 สร้างตัวอย่างของ XML พาเวอร์เดอร์ของ Microsoft และนำเอาไฟล์ XML ใส่ความจำ รหัสที่ 2 สร้างตัวอย่างของ XML พาเวอร์เดอร์อีกตัว และนำเอาไฟล์ XSL ใส่ความจำ บรรทัดสุดท้ายใช้เอกสาร XSL ที่เป็น XHTML และส่งผลลัพธ์ไปยังเบราเซอร์ของคุณ งานเสร็จแล้ว!

ดูว่ามันทำงานได้อย่างไร.