XSLT - На сервере
- Предыдущая страница XSLT на клиентской стороне
- Следующая страница Редактирование XML с помощью XSLT
Поскольку не все браузеры поддерживают XSLT,另一种 решение - преобразовать XML в XHTML на сервере.
Решение для работы во всех браузерах
В предыдущих главах мы объяснили, как использовать XSLT в браузерах для преобразования XML в XHTML. Мы создали段使用 XML-парсера для преобразования. Решение на JavaScript не работает в браузерах без 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>
и соответствующие таблицы стилей 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>Моя коллекция компакт-дисков</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>
Обратите внимание, что этот файл XML не содержит ссылок на файлы XSL.
Важно:Это означает, что файл XML можно преобразовать с использованием нескольких различных таблиц стилей XSL.
Преобразование XML в XHTML на сервере
Это код на сервере, который преобразует файл XML в XHTML:
<% 'Загрузка 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, вы можете изучить нашТутorial ASP>
Первый код создает экземпляр XML-парсера Microsoft и загружает XML-файл в память. Второй код создает другой экземпляр парсера и загружает XSL-файл в память. Последняя строка кода использует XSL-документ для преобразования XML-документа и отправляет результат в ваш браузер в виде XHTML. Задача выполнена!
- Предыдущая страница XSLT на клиентской стороне
- Следующая страница Редактирование XML с помощью XSLT