【PHP8.x】childNodesプロパティの使い方

childNodesプロパティの使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

childNodesプロパティは、特定のHTMLまたはXML要素が持つすべての子ノードのリストを保持するプロパティです。このプロパティは、PHPのDOM拡張機能におけるDom\HTMLElementクラスに属しており、HTMLやXMLドキュメントの構造をプログラムから操作する際に非常に重要な役割を果たします。

このプロパティにアクセスすると、Dom\NodeListオブジェクトが返されます。Dom\NodeListは、対象の要素が持つすべての子ノード(例えば、他の要素ノード、テキストノード、コメントノードなど)の集合を表すライブコレクションです。ライブコレクションとは、元のドキュメントツリーの構造が変更されると、NodeListの内容も自動的に更新されることを意味します。これにより、常に最新の子ノードの状態を取得できます。

childNodesプロパティは読み取り専用であり、直接子ノードを追加したり削除したりすることはできません。子ノードの追加や削除、あるいは並び替えを行う場合は、Dom\HTMLElementクラスのappendChild()removeChild()といった、より適切なメソッドを使用する必要があります。

このプロパティを使用することで、指定した要素の直下にある全ての子ノードを順番に走査したり、特定の子ノードの情報を取得したりすることが可能になります。例えば、HTMLの<div>要素の子ノードを取得して、その中の<p>要素や<img>要素などを識別し、それぞれの内容を処理するような場面で活用されます。システムエンジニアがWebページの内容を動的に変更したり、XMLデータから特定の情報を抽出したりする際に、DOMツリーの構造を理解し、childNodesプロパティを適切に活用することは、基盤となる重要なスキルとなります。

構文(syntax)

1<?php
2// Dom\Document クラスを使用してHTMLドキュメントを読み込みます。
3$document = new \Dom\Document();
4$document->loadHtml('<html><body><div id="exampleDiv"><p>これは段落です。</p>テキストノード<!--これはコメントです--></div></body></html>');
5
6// id="exampleDiv" を持つ要素を取得します。
7// 取得されるオブジェクトは \Dom\Element のインスタンスですが、
8// これは HTML 要素を表し、\Dom\HTMLElement クラスが提供するプロパティを利用できます。
9$htmlElement = $document->getElementById('exampleDiv');
10
11// $htmlElement の childNodes プロパティにアクセスし、子ノードの Dom\NodeList を取得します。
12$children = $htmlElement->childNodes;
13
14// 取得した子ノードのリストを反復処理し、それぞれのノードの情報を表示します。
15foreach ($children as $node) {
16    echo "ノード名: " . $node->nodeName;
17    if ($node->nodeType === \Dom\Node::TEXT_NODE || $node->nodeType === \Dom\Node::COMMENT_NODE) {
18        echo ", 内容: '" . trim($node->textContent) . "'";
19    }
20    echo "\n";
21}
22?>

引数(parameters)

引数なし

引数はありません

戻り値(return)

DOMNodeList

Dom\HTMLElementクラスのchildNodesプロパティは、その要素の子ノードをすべて格納したDOMNodeListを返します。DOMNodeListは、子ノードのコレクションであり、配列のようにアクセスしたり、ループ処理を行うことができます。

関連コンテンツ

関連プログラミング言語