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

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

作成日: 更新日:

基本的な使い方

nextElementSiblingプロパティは、所属するDOMCommentオブジェクトの次の兄弟要素ノードを保持するプロパティです。このプロパティは、現在のコメントノードと同じ親を持つ、直後にある要素ノードにアクセスするために使用されます。HTMLやXMLなどの文書構造を解析し、特定のコメントの後に続く要素をプログラム的に見つけ出す場面で非常に役立ちます。

具体的には、現在のコメントノードの直後に要素ノード(例えばHTMLの<div>タグや<p>タグなど)が存在する場合、その要素ノードを表すDOMElementオブジェクトがこのプロパティの値として返されます。一方で、もし直後に要素ノードが存在しない場合、例えば直後が別のコメントノード、テキストノード、あるいは親ノードの最後である場合は、nullが返されます。

このプロパティの大きな特徴は、要素ノードのみを対象とすることです。コメントノードやテキストノードといった要素ではない兄弟ノードはスキップされ、次に現れる要素ノードのみが考慮されます。PHP 8以降で利用可能であり、DOMツリーを効率的に移動し、必要な要素情報にアクセスするための重要な手段の一つです。

構文(syntax)

1<?php
2$html = <<<HTML
3<!DOCTYPE html>
4<html>
5<body>
6    <p>最初の要素</p>
7    <!-- これはDOMCommentノードです -->
8    <div id="next-element">2番目の要素</div>
9    <span>3番目の要素</span>
10</body>
11</html>
12HTML;
13
14$dom = new DOMDocument();
15$dom->loadHTML($html);
16
17$xpath = new DOMXPath($dom);
18$commentNodes = $xpath->query('//body/comment()');
19
20$targetComment = null;
21if ($commentNodes->length > 0) {
22    $targetComment = $commentNodes->item(0);
23}
24
25if ($targetComment) {
26    $nextElement = $targetComment->nextElementSibling;
27
28    if ($nextElement) {
29        echo "次の兄弟要素のタグ名: " . $nextElement->tagName . "\n";
30        echo "ID属性: " . $nextElement->getAttribute('id');
31    } else {
32        echo "次の兄弟要素は見つかりませんでした。";
33    }
34} else {
35    echo "コメントノードが見つかりませんでした。";
36}

引数(parameters)

引数なし

引数はありません

戻り値(return)

戻り値なし

戻り値はありません

関連コンテンツ

関連プログラミング言語