На момент написания книги в одном процессоре XSLT элемент
<xsl:document>
был реализован: это Saxon версии 6.2.1 и старше, в котором свой элемент
<saxon:output>
был изменен на
<xsl:document>
. Но пока это единственный известный мне процессор XSLT, поддерживающий этот элемент.
Элемент <xsl:namespace-alias>: генерация таблиц стилей
Одна из основных задач XSLT состоит в преобразовании одних таблиц стилей в другие, хотя на первый взгляд это может быть неочевидно.
Например, вам может потребоваться обработать длинные правила, которые нужно настроить непосредственно перед обработкой документов. И, как вы знаете, первоначально XSLT был представлен прежде всего для облегчения создания таблиц стилей объектов форматирования.
Но это порождает проблему: если вы обрабатываете таблицу стилей, полную таких элементов, как
<xsl:template>
и
<xsl:apply-templates>
, которые вы хотите видеть в результирующем документе — поскольку результирующий документ сам является таблицей стилей — как XSLT сможет отличить эти элементы буквального результата от элементов XSLT, которые он должен обработать?
Тут на помощь приходит элемент
<xsl:namespace-alias>
, поскольку он позволяет использовать новое пространство имен для элементов в исходном документе и преобразовывать это пространство имен обратно в правильное в результирующем документе. У элемента два атрибута:
•
stylesheet-prefix
(обязательный). Префикс пространства имен, используемый в таблице стилей. Устанавливается в NCName или «#default»;
•
result-prefix
(обязательный). Префикс, URI которого вы хотите присвоить пространству имен в результирующем документе. Устанавливается в NCName или «#default».
Следующий пример пояснит сказанное. Представьте, что вам нужно создать такую таблицу стилей:
Заметьте, что здесь много элементов XSLT с префиксом «xsl», — значит, если вы попытаетесь создать их при помощи XSLT-преобразования, процессор XSLT попытается выполнить эти элементы. Чтобы избежать такой ситуации, я задал им новый префикс пространства имен, «xslt». Ниже показано, как это выглядит в таблице стилей, производящей предыдущую таблицу
стилей (листинг 9.4). Заметьте, что нижеследующая таблица стилей просто выбирает корневой элемент исходного документа, чтобы она могла начать работать; она не использует исходный документ ни для каких других целей.
Листинг 9.4. Применение <xsl:namespace-alias>
<xsl:stylesheet version="1.1"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xslt="http://xslt">
<xsl:template match="/">
<xslt:stylesheet version="1.1">
<xslt:template match="PLANET">
<TR>
<TD><xslt:value-of select="NAME"/></TD>
<TD><xslt:applу-templates select="MASS"/></TD>
<TD><xslt:apply-templates select="RADIUS"/></TD>
<TD><xslt:apply-templates select="DAY"/></TD>
</TR>
</xslt:template>
</xslt:stylesheet>
</xsl:template>
.
.
.
</xsl:stylesheet>
Здесь я использую пространство имен "http://xslt" для префикса "xslt", но я смогу изменить его в выходном документе на правильное пространство имен XSLT, "http://www.w3.org/1999/XSL/Transform", воспользовавшись элементом