(PHP 5)
DOMDocument::getElementById — Ищет элемент с заданным id
Эта функция является аналогом DOMDocument::getElementsByTagName, но ищет элемент по его id.
Для работы этой функции необходимо либо задать ID атрибуты элементов посредством DOMElement::setIdAttribute, либо понадобится DTD, которая определяет атрибут как имеющий тип ID. В последнем случае перед использованием этой функции потребуется проверять документ на действительность посредством DOMDocument::validate или DOMDocument::$validateOnParse.
elementId
Уникальный id элемента.
Возвращает объект DOMElement либо NULL
, если элемент
не найден.
Пример #1 DOMDocument::getElementById() Example
Следующие примеры используют файл book.xml, который содержит следующие данные:
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE books [ <!ELEMENT books (book+)> <!ELEMENT book (title, author+, xhtml:blurb?)> <!ELEMENT title (#PCDATA)> <!ELEMENT blurb (#PCDATA)> <!ELEMENT author (#PCDATA)> <!ATTLIST books xmlns CDATA #IMPLIED> <!ATTLIST books xmlns:xhtml CDATA #IMPLIED> <!ATTLIST book id ID #IMPLIED> <!ATTLIST author email CDATA #IMPLIED> ]> <?xml-stylesheet type="text/xsl" href="style.xsl"?> <books xmlns="http://books.php/" xmlns:xhtml="http://www.w3.org/1999/xhtml"> <book id="php-basics"> <title>PHP Basics</title> <author email="[email protected]">Jim Smith</author> <author email="[email protected]">Jane Smith</author> <xhtml:blurb><![CDATA[ <p><em>PHP Basics</em> provides an introduction to PHP.</p> ]]></xhtml:blurb> </book> <book id="php-advanced"> <title>PHP Advanced Programming</title> <author email="[email protected]">Jon Doe</author> </book> </books>
<?php
$doc = new DomDocument;
// Необходимо проверить документ на действительность перед тем как
// ссылаться на id
$doc->validateOnParse = true;
$doc->Load('book.xml');
echo "Элемент с id 'php-basics': " . $doc->getElementById('php-basics')->tagName . "\n";
?>
Результат выполнения данного примера:
Элемент с id 'php-basics': book