XSLT - palvelimella
- Edellinen sivu XSLT asiakaspuolella
- Seuraava sivu XSLT muokkaa XML:ää
Koska kaikki selaimet eivät tue XSLT:ää, toinen ratkaisu on suorittaa XML:n muuntaminen XHTML:ksi palvelimella.
Ylivoimainen ratkaisu
Edellisessä luvussa olemme käsitelleet, miten XSLT:ää käytetään selaimessa XML:n muuntamiseen XHTML:ksi. Luomme JavaScript-koodia XML-parsin avulla muuntamista varten. JavaScript-ratkaisu ei toimi selaimissa, joissa ei ole XML-parsinta. Jotta XML-data sopii kaikille selaimille, meidän on muunnettava XML-dokumentti palvelimella ja lähetettävä se selaimelle XHMTL-muodossa.
Tämä on toinen XSLT:n etuja. Yksi XSLT:n suunnittelutavoitteista on tehdä mahdolliseksi muuntaa data palvelimella yhdestä muodosta toiseen ja palauttaa luettavaa dataa kaikille tyyppisille selaimille.
XML- ja XSL-tiedostot
Katso tämä XML-dokumentti, joka on esitetty edellisessä luvussa:
<?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>
Tarkastele tätä XML-tiedostoa.
sekä mukana toimitettavat XSL-tyylitaulut:
<?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>Minun CD-kokoelmani</h2> <table border="1"> <tr bgcolor="#9acd32"> <th align="left">Otsikko</th> <th align="left">Artisti</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>
Tarkastele tätä XSL-tiedostoa.
Huomaa, että tämä XML-tiedosto ei sisällä viittauksia XSL-tiedostoon.
Tärkeä huomio:Yllä oleva lause osoittaa, että XML-tiedostoa voidaan muuntaa useilla eri XSL-tyyleillä.
XML:n muuntaminen XHTML:ksi palvelimella
Tämä on koodi, joka suoritetaan palvelimella XML-tiedoston muuntamiseksi XHTML:ksi:
<% Lataa XML set xml = Server.CreateObject("Microsoft.XMLDOM") xml.async = false xml.load(Server.MapPath("cdcatalog.xml")) Lataa XSL set xsl = Server.CreateObject("Microsoft.XMLDOM") xsl.async = false xsl.load(Server.MapPath("cdcatalog.xsl")) Muunna tiedosto Response.Write(xml.transformNode(xsl)) %>
Vinkki:Jos et tiedä, miten kirjoittaa ASP:ää, voit oppia meidänASP oppimispaketti》
Ensimmäinen koodirivi luo Microsoftin XML-parsin instanssin ja luo XML-tiedoston muistiin. Toinen koodirivi luo toisen parsin instanssin ja luo XSL-tiedoston muistiin. Viimeinen rivi käyttää XSL-dokumenttia muuntaakseen XML-dokumentin ja lähettää tuloksen XHTML:ksi selaimeesi. Tehtävä valmis!
- Edellinen sivu XSLT asiakaspuolella
- Seuraava sivu XSLT muokkaa XML:ää