Технология XSLT
Шрифт:
Если аргумент функции опущен, она выполняется со строковым значением контекстного узла.
Примеры
normalize-space(' А - В - С ')
→ 'А-В-С'
normalize-space('А &#х9; В &#х9; С') > 'A B C'
Функция translate
string translate(string, string, string)
Функция
translate
Пример
translate('abcdefgh', 'aceg', 'ACEG')
→ 'AbCdEfGh'
Если некоторый символ повторяется во втором аргументе несколько раз, учитывается только первое его появление.
Пример
translate('abcdefgh', 'acaeaga', 'ACBECGD')
→ 'AbCdEfGh'
Если второй аргумент длиннее третьего, символы, для которых нет соответствующей замены, удаляются из строки.
Пример
translate('a b-c=d+e|f/g\h', 'aceg-=+|/\', 'ACEG')
→ 'AbCdEfGh'
Если третий аргумент длиннее второго, остаток строки игнорируется.
Пример
translate('abcdefgh', 'aceg', 'ACEGBDFH')
→ ' AbCdEfGh'
Функцию
translate
можно использовать, например, для изменения регистра символов. Конечно, это будет работать только для тех языков, для которых такая функция будет записана, но и этого в большинстве случаев будет достаточно. В будущем предполагается включить в новые версии языка более мощные функции для работы с регистрами символов. Пример
Для того чтобы изменять регистр слов русского языка, мы можем определить две переменные,
lowercase
и uppercase
, которые будут содержать строчные и прописные символы основного русского алфавита (мы включили в него букву ё — строчную ("ё
") и прописную ("Ё
"), хотя в соответствии с Unicode она относится к расширениям). Мы также создадим два именованных шаблона, которые будут менять регистр символов строкового параметра str
. Для удобства использования мы вынесем определения переменных и шаблонов во внешний модуль ru.xsl
. Листинг 6.6. Преобразование ru.xsl
<xsl:stylesheet
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:variable
name="uppercase"
select="concat('АБВГ',
'ДЕЁЖЗ',
'ИЙКЛ',
'МНОП',
'РСТУ',
'ФХЦЧ',
'ШЩЪЫ',
'ЬЭЮЯ')"/>
<xsl:variable
name="lowercase"
select="concat('абвг',
'деёжЗ',
'ийкл',
'мноп',
'рсту',
'фхцч',
'шщъы',
'ьэюя')"/>
<xsl:template name="lower">
<xsl:param name="str"/>
<xsl:value-of select="translate($str, $uppercase, $lowercase)"/>
</xsl:template>
<xsl:template name="upper">
<xsl:param name="str"/>
<xsl:value-of select="translate($str, $lowercase, $uppercase)"/>
</xsl:template>
</xsl:stylesheet>
Использовать
этот модуль можно, включив или импортировав его в основное преобразование элементамиxsl:include
или xsl:import
. После этого в основном преобразовании будут доступны переменные lowercase
и uppercase
, которые можно будет использовать в функции translate
и шаблоны с именами lower
и upper
. Использовать функцию
translate
с переменными lowercase
и uppercase
можно следующим образом: translate('Дом', $uppercase, $lowercase)
→ 'дом'
translate('Дом', $lowercase, $uppercase)
→ 'ДОМ'
Именованные шаблоны можно вызывать элементом
xsl:call-template
, передавая параметр при помощи xsl:with-param
. Например, следующий фрагмент шаблона ...
<xsl:call-template name="lower">
<xsl:with-param name="str" select="'Дом'"/>
</xsl:call-template
> ...
создаст в выходящем дереве текстовый узел со значением "
дом
". Функции множеств узлов
Функции last и position
number last
Поделиться с друзьями: