РНР 5 в подлинникеСтраница 434 из 554 |
||
|
Гпава 40. Пути-дорожки: язык XPath 877 nodeList query(string XPath) Метод производит поиск в документе узлов, удовлетворяющих условию, заданному в строке XPath. В результате поиска возвращается объект класса nodeList, содержащий список найденных узлов. void registerNamespace(string prefix, string namespace) МеТОД СВЯЗЫВаеТ Префикс prefix С указанной областью Имен namespace. Описание класса nodeList вы можете найти в разд. "Классы NodeList u NamedNodeMap" гл. 37. Напомним, что объект данного класса имеет свойство length, содержащее число узлов в списке, и метод item (number), возвращающий узел списка с указанным номером. Как мы уже упоминали в гл. 39, существует документ, описывающий интерфейс XPath для стандарта DOM: Document Object Model Level 3 Xpath (Объектная модель документа, третий уровень, XPath), http://www.w3.org/TR/2003/CR-DOM-Level-3-XPath-20030331/. Интерфейс, реализованный в настоящее время в РНР 5, отличается от данных рекомендаций. В данной главе мы будем рассматривать примеры запросов к XML-документу (chapter.xml), изображенному на рис. 40.1. Этот документ представляет собой выборку из XML-документа описания гл. 37 (в качестве примера был взят рабочий документ, поэтому его вид может отличаться от окончательного). На рисунке отображен результат выполнения запроса: ../../* I /*/Глава[2]//text() Сам запрос состоит из двух частей, разделенных символом [. Обе части задают адрес (LocationPath) до искомых узлов. Язык XPath имеет два способа адресации: □ относительная адресация (RelativeLocationPath); □ абсолютная адресация (AbsoluteLocationPath). Относительная адресация задает путь до искомых узлов относительно какого-либо базового узла. В языке XPath базовый узел носит название контекстного узла (context node). В данном примере роль контекстного узла (на рис. 40.1 он выделен подчеркиванием) выполняет узел с атрибутом имя 1-й таблицы 1-го раздела 1-й главы части. Обратите внимание, что в роли контекстного узла может выступать любой узел XML-документа. На языке XPath данный адрес записывается следующим образом: /Часть/Глава[1]/Раздел[1]/Таблица[1]/@имя Первая часть запроса: ../../* определяет путь по отношению к этому узлу. Запрос указывает на все элементы (*) узла раздел, который является родителем родителя (../..) контекстного узла атрибута имя. Данному запросу соответствуют узлы р, таблица, р (выделены жирным шрифтом) раздела "XML-расширения языка РНР". С точки зрения стандарта DOM, элемент таблица не является родителем узла атрибута имя данного элемента. Если дочерние элементы имеют ссылку ParentNode на родительский элемент, то узлы атрибутов имеют ссылку ownerEiement на элемент,
878 Часть VI. XML в РНР 5 к которому они принадлежат. XPath использует упрощенный подход, с точки зрения которого элемент является родителем как для своих дочерних элементов, так и для своих атрибутов. И в том и другом случае для доступа к нему применяется аббревиатура "..". Но и в стандарте DOM, и в языке XPath узлы атрибутов не являются дочерними узлами элемента. Для адресации узлов атрибутов служит префикс @. То есть с точки зрения XPath узлы атрибутов являются "незаконнорожденными". Они признают его отцовство, он признает их наследниками только с префиксом @. Вторая часть запроса: /*/глава[2]//text о задает абсолютный адрес. Все абсолютные адреса начинаются с символа /, означающего узел документа (обратите внимание — не корневой элемент, а корневой узел класса domDocument). При абсолютной адресации контекстный узел не принимается во внимание. Запрос /*/глава[2]//texto задает список всех текстовых узлов (//texto) второй главы документа (выделены жирным шрифтом). Файл: chapter.xml Узел (контекст).7Часть/Глава[1]/Раэдел[1]/Таблица[1]/@имя запрос: ../../* | /7Глава[2]/Лех1() <?xm!-styleshheet type="t8xt/css" href="chaptersryle.css"?> <Часть имя='ХМ|_ в РНР5'> <Глава имя-основы XML'> ^Р>Наряду с внедрением новой объектно-ориентированной модели. ..</Р> <Раздел имя-ХМL-расширения языка РНР><!- 1-й раздел главы -> <Р>Модуль xml (здесь и далее . с/Р> < Таблица имя-Список ХМ L-расширений языка РН Р>. <Даблица> <Р>Для обеспечения возможности работы с XML-данными ..<7Р> г/Раздел? < Раздел имя^'Основные понятия XML"> <Р>Яэык ХМL является языком описания документов...<р> <Рисунок имя-Иерархическая структура XML-документа' src=ymlstruct.gif/> <Р>Основным понятием языка ХМ L является узел (Node) </Р> <Листинг имя='Пример описания программы передач на языке XML' src-'progxm\'!> <Р>Надеюсь. читающие данные строки.. ,</Р> «/Раздел? </Глава> <Глава имя=ТСМ - объектная модель XML-flOKyMeHTa'> «Р>В предыдущей главе мы рассмотрели метод генерации ...</Р> .<Раэдел имя-Кодировки':- <Р?Стандарт DOM рассматривает три типа кодировки: <UL> <LI>BxoflHaR кодировка...<)LI> <^1>Внутренняя кодировка...</LI> <и>Выходная кодировка...</LI> </UL? Входная и выходная кодировки... </Р> «Листинг имя-Фикции перевода строк из кодировки KOI8-R в UTF-8 и обратно' src='unicode-koi8-r inc'/> <И> </Раздел> </Глава> </Часть> Рис. 40.1. Пример XML-документа с выделенными узлами Программа отображения результата XPath-запроса В качестве повторения изученного материала рассмотрим программу отображения узлов, удовлетворяющих XPath-запросу в формате, изображенном на рис. 40.1. |
| |
|
В начало ←предыдущая следующая→ ... 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 ... | ||