Чтение онлайн

ЖАНРЫ

Холзнер Стивен

Шрифт:

<xsl:template match="NAME | MASS">

 <xsl:if test="self::NAME">

<xsl:value-of select="."/>

 </xsl:if>

 <xsl:if test="self::MASS">

<xsl:value-of select="."/>

<xsl:text> </xsl:text>

<xsl:value-of select="@UNITS"/>

 </xsl:if>

</xsl:template>

.

.

.

На

этом мы завершаем рассмотрение новых осей XPath. Давайте перейдем к примерам.

Примеры путей расположения

Мы изучили достаточно теории путей расположения. Но, понятно, лучше всего осваивать этот материал на примерах, поэтому я привожу следующий список примеров путей расположения (сокращенные варианты рассматриваются после этого списка):

• 

child::PLANЕТ
. Возвращает дочерние элементы
<PLANЕТ>
контекстного узла;

• 

child::text
. Возвращает все дочерние текстовые узлы контекстного узла;

• 

child::node
. Возвращает всех детей контекстного узла;

• 

attribute::UNIT
. Возвращает атрибут
UNIT
контекстного узла;

• 

descendant::PLANET
. Возвращает все элементы-потомки
<PLANET>
контекстного узла;

• 

ancestor::PLANET
. Возвращает всех предков
<PLANET>
контекстного узла;

• 

ancestor-or-self::PLANET
. Возвращает предков
<PLANET>
контекстного узла. Если контекстным узлом тоже является
<PLANET>
, возвращает также контекстный узел;

• 

descendant-or-self::PLANET
. Возвращает элементы-потомки
<PLANET>
контекстного узла. Если контекстным узлом тоже является
<PLANET>
, возвращает также контекстный узел;

• 

self::PLANET
. Возвращает контекстный узел, если им является элемент
<PLANET>
;

• 

child::PLANET/descendant::NAME
. Возвращает элементы-потомки
<NAME>
дочерних элементов
<PLANET>
контекстного узла;

• 

child::*/child::PLANET
. Возвращает всех внуков
<PLANET>
контекстного узла;

• 

/
. Возвращает корневой узел;

• 

/descendant::PLANET
. Возвращает все элементы
<PLANET>
в документе;

• 

/descendant::PLANET/child::NAME
. Возвращает все элементы
<NAME>
с родителем
<PLANET>
в документе;

• 

child::PLANET[position=3]
. Возвращает третьего ребенка
<PLANET>
контекстного узла;

• 

child::PLANET[position=last]
. Возвращает последнего ребенка
<PLANET>
контекстного узла;

• 

/descendant::PLANET[position = 3]
. Возвращает третий элемент
<PLANET>
в документе;

• 

child::PLANETS/child::PLANET[position=4]/child::NAME[position=3]
.
Возвращает третий элемент
<NAME>
четвертого элемента
<PLANET>
элемента
<PLANETS>
;

• 

child::PLANET[position>3]
. Возвращает всех детей
<PLANET>
контекстного узла после первых трех;

• 

preceding-sibling::NAME[position=2]
. Возвращает второй предыдущий элемент-брат
<NAME>
контекстного узла;

• 

child::*[self::NAME or self::MASS]
. Возвращает детей
<NAME>
и
<MASS>
контекстного узла.

• 

child::*[self::NAME or self::MASS][position=last]
. Возвращает последнего ребенка
<NAME>
или
<MASS>
контекстного узла.

Как видите, синтаксис некоторых выражений достаточно запутан, и набирать их также довольно долго. Но, как и для образцов, существует сокращенная форма синтаксиса XPath.

Сокращенный синтаксис XPath

Сокращения синтаксиса XPath могут быть весьма удобными. Ниже приведены правила:

• 

self::node
может быть сокращено как
.
;

• 

parent::node
может быть сокращено как
..
;

• 

child::childname
может быть сокращено как
childname
;

• 

attribute::childname
может быть сокращено как
@childname
;

• 

/descendant-or-self::node/
может быть сокращено как
//
.

Например, путь расположения

.//PLANET
— сокращение для
self::node/descendant-or-self::node/child::PLANET
. Можно также сократить выражение предиката
[position=3]
как
[3]
,
[position=last]
как
[last]
и т.д. Работать с путями расположения XPath при помощи сокращенного синтаксиса значительно проще. В следующем списке перечислен ряд примеров путей расположения с использованием сокращенного синтаксиса:

• 

PLANET
возвращает дочерние элементы
<PLANET>
контекстного узла;

• 

*
возвращает все дочерние элементы контекстного узла;

• 

text
возвращает все дочерние текстовые узлы контекстного узла;

• 

@UNITS
возвращает атрибут
UNITS
контекстного узла;

• 

@*
возвращает все атрибуты контекстного узла;

• 

PLANET[3]
возвращает третьего ребенка
<PLANET>
контекстного узла;

• 

PLANET[last]
возвращает последнего ребенка
<PLANET>
контекстного узла;

• 

*/PLANET
возвращает всех внуков
<PLANET>
контекстного узла;

• 

/PLANETS/PLANET[3]/NAME[2]
возвращает второй элемент
<NAME>
третьего элемента
<PLANET>
элемента
<PLANETS>
;

• 

//PLANET
возвращает всех потомков
<PLANET>
корня документа;

Поделиться с друзьями: