Алексей Валиков - Технология XSLT
- Название:Технология XSLT
- Автор:
- Жанр:
- Издательство:БХВ-Петербург
- Год:2002
- Город:Санкт-Петербург
- ISBN:нет данных
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Алексей Валиков - Технология XSLT краткое содержание
Книга посвящена разработке приложений для преобразования XML-документов с использованием XSLT — расширяемого языка стилей для преобразований. Обсуждается применение языков XSLT и XPath в решении практических задач: выводу документов в формате HTML, использованию различных кодировок для интернационализации и, в частности, русификации приложений, вопросам эффективности существующих подходов для решения проблем преобразования. Для иллюстрации материала используется большое количество примеров.
Для начинающих и профессиональных программистов
Технология XSLT - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Область нумерации метода multiple
определяется так же, как и в случае с методом single
: учитываются только потомки ближайшего предка текущего узла, удовлетворяющего паттерну, указанному в атрибуте from
.
Вычисление списка номеров узлов выполняется в два этапа:
□ На первом этапе выбирается множество нумеруемых узлов, удовлетворяющее следующим условиям:
• его узлы принадлежат оси навигации ancestor-or-self
текущего узла;
• его узлы соответствуют паттерну count
;
• его узлы принадлежат области подсчета.
□ На втором этапе для каждого узла нумеруемого множества вычисляется позиция среди собратьев. Позиция нумеруемого узла будет равна 1
плюс количество узлов, принадлежащих его оси навигации preceding-sibling
и соответствующих паттерну count
.
Для демонстрации вычисления номеров на нескольких уровнях дерева документа проследим за выполнением инструкции
format=" 1.1."
level="multiple"
count="doc|chapter|para"
from="doc"/>
при обработке того же элемента para
.
Прежде всего, надо определить область подсчета. Значением атрибута from
является паттерн doc
, значит, подсчет будет вестись среди всех потомков ближайшего к текущему элементу para
предка, который является элементом doc
. Это множество выделено на рис. 8.6 штрих-пунктирной линией.

Рис. 8.6. Определение области подсчета
Следующим шагом выберем узлы, принадлежащие оси навигации ancestor-or-self
текущего узла para и удовлетворяющие паттерну doc|chapter|para
. Это множество будет включать сам текущий элемент, а также его предки chapter
и doc
. На рис. 8.7 они обведены пунктиром.

Рис. 8.7. Первый шаг вычисления номера
Следующим шагом оставим только те из выбранных узлов, которые входят в область подсчета. Эти узлы обведены на рис. 8.8 пунктиром.

Рис. 8.8. Второй шаг вычисления номера
Мы получили множество узлов, состоящее всего из двух элементов — chapter
и para
вследствие того, что элемент doc
был исключен как не входящий в область подсчета. Выделим множества пересчитываемых узлов, предшествующих нумеруемым элементам (рис. 8.9).

Рис. 8.9. Третий шаг вычисления номера
В этом примере элемент chapter
, так же как и элемент para
, будет иметь номер 2
. Соответственно, результатом выполнения инструкции xsl:number
в этом случае будет строка
2.2.paragraph 14
Метод any
используется для того, чтобы вычислить номер узла, основываясь на его позиции среди всех учитываемых узлов элемента.
Областью нумерации этого метода будет множество всех узлов, следующих в порядке просмотра документа за первым предком текущего узла, который удовлетворяет паттерну, указанному в атрибуте from
.
Номер вычисляется как 1
плюс количество узлов области подсчета, удовлетворяющих паттерну count
и предшествующих в порядке просмотра документа текущему узлу.
В качестве примера применения метода any
вычислим порядковый номер элемента para
среди всех элементов документа, начиная со второй главы. Инструкцию такого рода мы запишем в виде
format=" 1."
level="any"
count="*"
from="chapter[2]"/>
При ее выполнении мы сначала определим область, в которой будут подсчитываться узлы (обведены штрих-пунктирной линией на рис. 8.10).

Рис. 8.10. Определение области подсчета узлов
Следующим шагом выделим подмножество области подсчета, предшествующее в порядке просмотра текущему узлу para
(рис. 8.11).

Рис. 8.11. Первый шаг вычисления номера
Выделенное множество содержит 11 узлов, значит, искомый номер будет равен 12
.
Перед тем, как перейти к рассмотрению способов форматирования номеров, приведем итоговый пример (листинг 8.34), в котором в шаблонах будут использоваться все три метода нумерации.
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"»
Resulting document
==================
level="multiple"
count="chapter|section"/>
format=" a) "
level="any"
count="para"/>
Опишем словесно нумерацию, которая будет применяться в этом преобразовании.
□ Элементы chapter
будут нумероваться в соответствии со своей позицией среди других элементов chapter
того же уровня.
□ Элементы section
будут нумероваться при помощи многоуровневой нумерации — номер будет состоять из номера элемента chapter
и номера самого элемента section
.
□ Элементы para
будут нумероваться исходя из своей позиции среди всех остальных элементов para
вне зависимости от того, на каких уровнях в документе они находятся.
Результатом применения этого преобразования к документу, приведенному в листинге 8.31, будет следующий текст.
Resulting document
==================
1. First chapter
1.1 First section
a) paragraph 1
b) paragraph 2
c) paragraph 3
1.2. Second section
d) paragraph 4
e) paragraph 5
2. Second chapter
2.1 Third section
f) paragraph 6
g) paragraph 7
h) paragraph 8
i) paragraph 9
2.2 Forth section
j) paragraph 10
k) paragraph 11
l) paragraph 12
2.3 Fifth section
m) paragraph 13
n) paragraph 14
o) paragraph 15
p) paragraph 16
3. Third chapter
3.1 Sixth section
q) paragraph 17
r) paragraph 18
Форматирование номеров
Возвращаясь немного назад, напомним, что результатом первого этапа выполнения xsl:number
является список номеров, который может быть пустым или содержать одно или несколько чисел. Несложно увидеть, что количество номеров в этом списке будет зависеть от следующих условий.
□ Список номеров будет пустым, если в области нумерации не оказалось нумеруемых узлов.
Читать дальшеИнтервал:
Закладка: