document()¶
Функция document
позволяет обращаться к внешним документам по их URI.
Синтаксис¶
1 |
|
Описание и примеры¶
Функция document
возвращает множество узлов. В простейшем случае это множество будет состоять из корневого узла внешнего документа. Функцию document
можно использовать в более сложных XPath-выражениях, например в выражениях фильтрации. Так функция
1 2 3 |
|
скопирует все элементы а, находящиеся в теле (/html/body
) внешнего документа.
Базовый сценарий использования функции document
очень прост: ей передается строка, содержащая URI внешнего ресурса, а результатом является множество узлов, состоящее из корня внешнего документа. Однако на этом возможности document
не заканчиваются. Мы рассмотрим несколько вариантов вызова функции document
с параметрами различного типа.
Вызов document( string )¶
В случае если функции document
передана строка, возвращаемое множество будет состоять из корневого узла внешнего документа. URI этого документа как раз и сообщается строковым аргументом функции document
.
Интересной особенностью является возможность передать пустую строку:
1 |
|
В этом случае document
возвратит корневой узел самого преобразования. При помощи document('')
можно получать доступ к информации, хранящейся в самом преобразовании (оно ведь тоже является ХМL-документом). К сожалению, перед обращением к документу не существует способа проверить его существование. Процессор может либо выдать ошибку, либо возвратить пустое множество.
Пример¶
Листинг 8.61. Преобразование
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
|
Листинг 8.62. Выходной документ
1 2 |
|
Вызов document( node-set )¶
Передавая функции document
множество узлов, можно получить доступ к нескольким документам, URI которых являются строковыми значениями узлов множества. Это, в частности, позволяет обращаться к документам, URI которых указаны в узлах обрабатываемого документа. Например, в контексте элемента
1 |
|
вполне корректным вызовом функции document
будет document(@href)
.
Выражение @href
— здесь возвращает множество, состоящее из единственного узла атрибута. Его строковое значение ("http://www.w3.org"
) будет использовано как URI внешнего документа. Результирующее множество узлов будет содержать единственный корневой узел документа, расположенного по адресу http://www.w3.org
.
Приведем еще один пример. XPath-выражение //a/@href
возвращает множество всех атрибутов href
элементов а
текущего документа. Тогда множество document(//a/@href)
будет содержать корневые узлы всех документов, на которые ссылается посредством элементов а текущий документ.
Вызов document( string, node-set )¶
URI, которые передаются функции document
, могут быть как абсолютными, так и относительными, например document('doc.xml')
возвратит корень документа doc.xml
, находящегося в том же каталоге, что и само преобразование.
Функция document
позволяет менять "точку отсчета" относительных URI. Если в качестве второго аргумента функции document
передано множество узлов, то относительные идентификаторы ресурсов будут отсчитываться от базового адреса первого (в порядке просмотра документа) узла этого множества.
Базовым URI узла дерева является:
- если элемент или инструкция по обработке принадлежит внешней сущности, базовым URI соответствующего узла будет URI внешней сущности;
- иначе базовым URI является URI документа;
- базовым URI текстового узла, узла атрибута, комментария или пространства имен является базовый URI родительского элемента.
Поясним вышесказанное на примерах.
Конструкция
1 |
|
копирует в выходящий документ doc.xml
, находящийся в одном каталоге вместе с преобразованием.
Несмотря на то, что в следующем определении xsl:for-each
меняет контекст, document('doc.xml')
все равно возвращает корень документа doc.xml
, находящегося в одном с преобразованием каталоге:
1 2 3 |
|
В следующей конструкции document('doc.xml', /)
копирует документ a/doc.xml
, поскольку в качестве базового URI используется URI корня документа a/data.xml
:
1 2 3 |
|
Того же самого эффекта можно достичь следующим образом:
1 2 3 |
|
В следующей конструкции за базовый URI опять принимается URI самого преобразования (вернее, его корневого узла):
1 |
|
Протестируем теперь все это вместе в одном преобразовании.
Листинг 8.63. Преобразование
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 |
|
Листинг 8.64. Документ doc.xml
1 |
|
Листинг 8.65. Документ a/doc.xml
1 |
|
Листинг 8.66. Выходящий документ
1 2 3 4 5 |
|
Вызов document( node-set, node-set )¶
Если функции document
передаются два множества узлов, то вычисление результата можно описать примерно следующим образом:
- каждый из узлов первого аргумента преобразуется в строковый вид;
- для каждого из полученных значений выполняется вызов типа document(string, node-set);
- результирующие множества объединяются.
Иными словами, document(node-set, node-set)
работает через document(string, node-set)
точно так же, как document(node-set)
работает через document(string)
. Разница лишь в том, что в первом случае базовый URI будет изменен.
Ссылки¶
- document() MDN (рус.)