Листинг 6.11. Преобразование
version="1.0"
xmlns:xsl="http: //www.w3.org/1999/XSL/Transform"
xmlns:a="http://www.a.com"
xmlns:b="http://www.b.com">
name="{name()}"
namespace-uri="{namespace-uri()}"
local-name="{local-name()}">
Листинг 6.12. Выходящий документ
xmlns:a="http://www.a.com"
xmlns:b="http://www.b.com"
name="a:a"
namespace-uri="http://www.a.com"
local-name="a">
namespace-uri="http://www.b.com"
local-name="b">
namespace-uri=""
local-name="c"/>
node-set id( object )
Мы уже встречались с функцией id
, когда говорили об уникальных атрибутах элементов и еще раз — когда разбирали паттерны. Функция id
позволяет обращаться к элементам по значениями их уникальных атрибутов.
Функция id
выполняется по-разному в зависимости от того, какой тип данных ей передается.
□ Если аргументом функции является строка, она рассматривается как набор идентификаторов, разделенных пробелами. В результирующее множество узлов войдут узлы тех элементов текущего документа, значения уникальных атрибутов которых входят в набор идентификаторов, определяемый строковым аргументом.
□ Если аргументом функции является множество узлов, результатом ее выполнения будет объединение результатов функции id
, примененной к строковому значению каждого из узлов множества.
□ Если аргументом функции является объект другого типа, аргумент вначале преобразуется в строку и функция id
выполняется как со строковым параметром.
Пример
Предположим, что мы используем XML для того, чтобы описать граф — множество вершин, соединенных дугами (рис. 6.11).
Рис. 6.11. Изображение графа, который мы будем описывать в XML
Каждой вершине будет соответствовать элемент vertex
. Для того чтобы описать все связи, мы дадим каждой вершине уникальное имя, которое будет записано в ее ID
-атрибуте name
. Имена вершин, с которыми она соединена, будут перечислены в атрибуте connects
типа IDREFS
.
Документ, описывающий этот граф, может выглядеть следующим образом.
Листинг 6.13. Документ gemini.xsl
Декларация типа документа вынесена во внешний файл gemini.dtd
.
Листинг 6.14. Файл gemini.dtd
name ID #REQUIRED
connects IDREFS #REQUIRED>
При обработке этого документа функция id
будет очень полезна для выбора элементов соединенных вершин. Действительно, функция id
, которой будет передано значение атрибута connects
(в котором через пробелы перечислены вершины, смежные данной), возвратит множество, состоящее из элементов с перечисленными уникальными идентификаторами. Так, например, функция id('tau upsilon')
возвратит множество, состоящее из двух элементов с атрибутами name, равными tau
и upsilon
соответственно.
Более того, функция id
может быть вычислена и от множества узлов. В этом случае ее значением будет объединение множеств, полученных в результате выполнения функции от строкового значения каждого узла переданного множества. Например, id(id('tau upsilon')/@connects)
возвратит множество, состоящее из вершин с именами alpha
, beta
, delta
, epsilon
, theta
, iota
и kappa
— множество вершин, смежных с вершинами tau и upsilon.
Приведем пример преобразования, которое в каждый элемент vertex
добавляет комментарий, в котором перечислены имена вершин, достижимых из текущей, не более чем за два шага.
Для того чтобы найти множество вершин, достижимых за один шаг (иначе говоря, смежных), мы воспользуемся выражением вида id(@connects)
, для выборки множества вершин, достижимых из текущей за два шага — выражением id(id(@connects)/@connects)
. Таким образом, множество вершин, достижимых не более чем за два шага, будет вычисляться как
id(@connects)|id(id(@connects)/@connects)
Листинг 6.15. Преобразование gemini.xsl
version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
Листинг 6.16. Выходящий документ
В этом разделе мы приведем базовые синтаксические правила языка XPath. Со многими из них мы уже встречались в правилах более высокого уровня, некоторые определены в спецификации для того, чтобы облегчить реализацию лексического разбора XPath-выражений в различных процессорах.
Читать дальше