<value>2</value>
<value>3</value>
</number>
</data>
Следующее преобразование демонстрирует использование относительных путей выборки в фильтрующих выражениях:
<xsl:stylesheet
version='1.0'
xmlns:xsl='http://www.w3.org/1999/XSL/Тransform'>
<xsl:template match='data'>
<values>
<xsl:copy-of select='(string | number)/value'/>
</values>
</xsl:template>
</xsl:stylesheet>
<values>
<value>a</value>
<value>b</value>
<value>c</value>
<value>1</value>
<value>2</value>
<value>3</value>
</values>
Элемент values
выходящего документа содержит множество, являющееся результатом вычисления выражения (string | number)/value
. Это будет множество элементов value
, принадлежащих элементам string
или number
.
Объединение множеств
Единственная операция над множествами, которая определена в XSLT, — это операция объединения. Если $nodeset1
и $nodeset2
— два множества узлов, то результатом вычисления
$nodeset1 | $nodeset2
будет множество узлов, которые принадлежат хотя бы одному из этих множеств.
Следует сказать, что, поскольку никакой тип данных не может быть преобразован во множество узлов, операнды объединения сами всегда должны быть множествами. То есть, выражение вида:
'а' | body/a
не добавит текстовый узел 'а
' к множеству элементов а
, принадлежащих элементу body
— оно просто будет некорректным.
Арифметические операции
Четыре основные бинарные операции — '+
', '-
', 'div
', 'mod
' и пятая, унарная операция отрицания '-
' обеспечивают в XSLT основные арифметические действия. Поскольку любой из типов данных может быть преобразован в численный тип, в качестве операндов арифметических операций можно использовать что угодно — например, вычитать из строки булевое выражение:
'0.5' - true()
→ -0.5
Следует осторожно обращаться со знаком '-
'. Имена элементов и атрибутов могут включать этот знак и поэтому выражение first-last
будет воспринято не как разность значений элементов first
и last
, а как путь выборки элементов с именами 'first-last
'. Для того чтобы избежать таких казусов, операторы всегда следует выделять пробелами:
first - last
Операции сравнения
В XSLT имеются следующие шесть операторов сравнения:
□ '=
' — равно;
□ '!=
' — не равно;
□ '<
' меньше;
□ '>
' больше;
□ '<=
' меньше или равно (не больше);
□ '>=
' больше или равно (не меньше).
Результат этих сравнений всегда имеет булевый тип, то есть сравнение может быть либо истинным, либо ложным. Несмотря на внешнюю очевидность функций этих операторов, наличие такого типа данных, как множество узлов, делает четкое определение сравнений довольно сложным. Мы приведем его так, как оно приведено в спецификации, снабдив подробными комментариями и примерами.
Операции сравнения определяются в спецификации в три этапа:
□ сначала сравнение, в котором участвуют множества узлов, определяется в терминах сравнения более простых типов данных;
□ затем для простых типов данных определяются равенство ('=
') и неравенство ('!=
');
□ наконец, для простых типов данных определяются сравнения '<
', '<=
', '>
', '>=
'.
Сравнение, хотя бы один из операндов которого является множеством узлов, определяется следующим образом:
□ если один из операндов является множеством узлов, а второй имеет булевый тип, сравнение будет истинным тогда и только тогда, когда истинным будет результат сравнения множества узлов, преобразованного к булевому типу и самого булевого операнда;
□ если один из операндов является множеством узлов, а второй имеет численный тип, сравнение будет истинным тогда и только тогда, когда во множестве узлов найдется такой узел, что сравнение текстового значения этого узла, преобразованного к числу, и самого численного операнда будет истинным;
□ если один из операндов является множеством узлов, а второй имеет строковый тип, сравнение будет истинным тогда и только тогда, когда во множестве узлов найдется такой узел, что сравнение его текстового значения и самого строкового операнда будет истинным;
□ если оба операнда являются множествами узлов, их сравнение будет истинным тогда и только тогда, когда найдется узел в первом множестве и узел во втором множестве, такие, что их сравнение будет истинным.