XSLT может быть использован для преобразования документа в XHTML в вашем браузере.
JavaScript Решение
В предыдущих главах мы объяснили, как XSLT может быть использован для преобразования документа из XML в XHTML. Мы сделали это путем добавления XSL таблицы стилей в файл XML и позволить браузеру сделать преобразование.Даже если это работает нормально, это не всегда желательно , чтобы включить ссылку на таблицу стилей в файле XML (eg it will not work in a non XSLT aware browser.) , (eg it will not work in a non XSLT aware browser.)
Более универсальное решение было бы сделать преобразование использовать JavaScript.
С помощью JavaScript, мы можем:
- сделать браузер конкретных испытаний
- использовать различные таблицы стилей в соответствии с обозревателем и потребностями пользователей
То есть красота XSLT! Одной из целей проектирования XSLT было сделать возможным преобразование данных из одного формата в другой, поддерживает различные браузеры и различные потребности пользователей.
XML-файл и XSL файлы
Посмотрите на документ XML, который вы уже видели в предыдущих главах:
<?xml version="1.0" encoding="UTF-8"?>
<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="UTF-8"?>
<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 style="text-align:left">Title</th>
<th style="text-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>
Notice that the XML file does not have a reference to the XSL file.
IMPORTANT: Данное предложение указывает на то, что файл XML может быть преобразован , используя много различных листов XSL стилей.
Преобразование XML в XHTML в браузере
Вот исходный код, необходимый для преобразования файла XML в XHTML на клиенте:
пример
<html>
<head>
<script>
function loadXMLDoc(filename)
{
if (window.ActiveXObject)
{
xhttp = new ActiveXObject("Msxml2.XMLHTTP");
}
else
{
xhttp = new XMLHttpRequest();
}
xhttp.open("GET", filename, false);
try {xhttp.responseType = "msxml-document"}
catch(err) {} // Helping IE11
xhttp.send("");
return xhttp.responseXML;
}
function displayResult()
{
xml = loadXMLDoc("cdcatalog.xml");
xsl = loadXMLDoc("cdcatalog.xsl");
// code for IE
if (window.ActiveXObject
|| xhttp.responseType == "msxml-document")
{
ex =
xml.transformNode(xsl);
document.getElementById("example").innerHTML
= ex;
}
// code for Chrome, Firefox, Opera, etc.
else if (document.implementation
&& document.implementation.createDocument)
{
xsltProcessor = new XSLTProcessor();
xsltProcessor.importStylesheet(xsl);
resultDocument =
xsltProcessor.transformToFragment(xml, document);
document.getElementById("example").appendChild(resultDocument);
}
}
</script>
</head>
<body onload="displayResult()">
<div
id="example" />
</body>
</html>
Попробуй сам " Tip: Если вы не знаете , как писать JavaScript, пожалуйста , изучить наш JavaScript учебник .
Пример Объяснение:
The loadXMLDoc() function does the following:
- Создание объекта XMLHttpRequest
- Используйте open() и send() методы объекта XMLHttpRequest , чтобы послать запрос на сервер
- Получить данные ответа как данные XML
The displayResult() function is used to display the XML file styled by the XSL file:
- Загрузка XML и XSL файлы
- Проверьте, какой браузер имеет пользователя
- Если Internet Explorer:
- Используйте transformNode() метод , чтобы применить таблицу стилей XSL к XML - документа
- Установить тело текущего документа (id="example") , чтобы содержать стилизованный документ XML
- Если другие браузеры:
- Создать новый объект XSLTProcessor и импортировать файл XSL к нему
- Используйте transformToFragment() метод , чтобы применить таблицу стилей XSL к XML - документа
- Установить тело текущего документа (id="example") , чтобы содержать стилизованный документ XML