Webエンジニア向けプログラミング解説動画をYouTubeで配信中!
▶ チャンネル登録はこちら

【PHP8.x】DOMComment::contains()メソッドの使い方

containsメソッドの使い方について、初心者にもわかりやすく解説します。

作成日: 更新日:

基本的な使い方

containsメソッドは、DOMCommentノード(コメントノード)が指定された文字列を含んでいるかどうかを判定するメソッドです。PHP 8.0以降で使用可能です。このメソッドは、コメントノードの内容全体に対して、指定された文字列が部分文字列として存在するかどうかを調べます。

システムエンジニアを目指す初心者の方にとって、DOMCommentノードはHTMLやXMLドキュメント内のコメントを表すオブジェクトだと考えると理解しやすいでしょう。containsメソッドを利用することで、特定のキーワードやフレーズがコメントに含まれているかをプログラムで効率的に確認できます。

例えば、HTMLのテンプレートエンジンなどで、特定の条件に基づいてコメントの内容を処理する必要がある場合に、このメソッドは非常に役立ちます。また、XMLドキュメントの解析において、特定のコメントを目印に処理を分岐させる場合などにも利用できます。

containsメソッドは、大文字と小文字を区別して文字列を検索します。もし大文字小文字を区別せずに検索したい場合は、strtolower関数やstrtoupper関数などを用いて、比較する文字列を事前に小文字または大文字に変換する必要があります。

戻り値は、指定された文字列がコメントノードに含まれている場合はtrue、そうでない場合はfalseとなります。このboolean型の戻り値を利用することで、条件分岐処理を記述し、プログラムの動作を制御することが可能です。このように、containsメソッドは、DOMDocumentを操作する上で、コメントノードの内容を検証するための重要なツールとなります。

構文(syntax)

1DOMComment::contains(string $needle, int $offset = 0): bool

引数(parameters)

DOMNode|DOMNameSpaceNode|null $other

  • DOMNode|DOMNameSpaceNode|null $other: 比較対象となるDOMNodeまたはDOMNameSpaceNodeオブジェクト、あるいはnull

戻り値(return)

bool

指定された文字列がDOMCommentノードのコンテンツに含まれている場合にtrueを、含まれていない場合にfalseを返します。

サンプルコード

PHP DOMComment contains配列チェック

1<?php
2
3/**
4 * 指定されたDOMCommentノードが、DOMノードの配列中のいずれかのノードを含んでいるかをチェックします。
5 * DOMComment::contains()は、対象ノードが自身であるか、その子孫である場合にtrueを返します。
6 * DOMCommentノードは通常、他のノードを子孫として持たないため、比較対象が自身と同一のノードである場合にのみtrueを返します。
7 *
8 * @param DOMComment $commentNode 基準となるDOMCommentノード。
9 * @param array<DOMNode|DOMNameSpaceNode|null> $nodesToCheck 含まれているかを確認するDOMノードの配列。
10 * @return bool 配列中のいずれかのノードがcommentNodeに含まれていればtrue。
11 */
12function checkCommentContainsAnyOfArray(DOMComment $commentNode, array $nodesToCheck): bool
13{
14    foreach ($nodesToCheck as $otherNode) {
15        // containsメソッドはDOMNode|DOMNameSpaceNode|nullを引数に取る
16        // nullの場合、containsは常にfalseを返す
17        if (($otherNode instanceof DOMNode || $otherNode instanceof DOMNameSpaceNode) && $commentNode->contains($otherNode)) {
18            return true;
19        }
20    }
21    return false;
22}
23
24// サンプルコードの実行
25$document = new DOMDocument();
26$element = $document->createElement('root');
27$document->appendChild($element);
28
29// 基準となるDOMCommentノードを作成し、DOMツリーに追加
30$myComment = $document->createComment('This is my important comment.');
31$element->appendChild($myComment);
32
33// 確認対象のDOMノードの配列を作成
34$nodesArray = [
35    $document->createComment('Another comment.'), // 他のコメントノード
36    $document->createTextNode('Some text content.'), // テキストノード
37    $myComment, // 自身と同一のDOMCommentノード(contains()がtrueを返す一般的なケース)
38    $document->createElement('child'), // 無関係なDOMElementノード
39    null // null値も含む
40];
41
42// checkCommentContainsAnyOfArray 関数を使って、myCommentがnodesArray内のいずれかのノードを含んでいるかを確認
43$doesCommentContainAny = checkCommentContainsAnyOfArray($myComment, $nodesArray);
44
45echo "Does 'myComment' contain any of the nodes in the array?\n";
46echo "Result: " . ($doesCommentContainAny ? "Yes" : "No") . "\n";
47
48?>

PHPのDOMComment::contains()メソッドは、特定のDOMコメントノードが、引数として指定された別のDOMノードまたは名前空間ノードを含んでいるかどうかを真偽値で判定します。このメソッドは、DOMNodeDOMNameSpaceNode、あるいはnullを受け取り、含まれていればtrue、そうでなければfalseを返します。

しかし、DOMCommentノードはDOMツリーにおいて、テキストや要素のような子ノードを持つことは通常ありません。そのため、DOMComment::contains()メソッドがtrueを返すのは、引数として渡されたノードが、比較対象となるDOMCommentノード自身である場合のみに限られます。nullが引数として渡された場合は、常にfalseを返します。

提示されたサンプルコードは、このDOMComment::contains()メソッドの挙動を理解するための具体的な例です。checkCommentContainsAnyOfArray関数は、基準となるDOMCommentノードが、与えられたDOMノードの配列の中に含まれるいずれかのノードを含んでいるかを確認します。この関数では、配列内の各ノードに対してcontains()メソッドを適用し、一つでもtrueになった時点で結果を返します。これにより、コメントノードが自分自身と一致するノードを配列内に持っている場合にのみtrueが出力されることを示しています。

このサンプルコードは、DOMツリーのコメントノード(DOMComment)が、与えられたノード配列中のいずれかのノードを含んでいるかをチェックするものです。DOMComment::contains()メソッドは、引数のノードが自身と同一であるか、その子孫である場合にtrueを返しますが、DOMCommentノードは通常、子ノードを持たないため、実際には比較対象のノードが基準となるDOMCommentノード自身と完全に同じインスタンスである場合にのみtrueが返されます。初心者が間違いやすい点として、このメソッドはコメント文字列の内容を検索するものではないことを強く意識してください。引数にはDOMノードやDOM名前空間ノード、またはnullを指定できますが、nullの場合には常にfalseが返されます。サンプルコードの関数は配列の各要素を個別にチェックしており、配列内の文字列検索とは異なりますのでご注意ください。

PHP DOMComment::contains メソッドの確認

1<?php
2
3/**
4 * DOMComment::contains メソッドの動作を示すサンプルコードです。
5 *
6 * このメソッドは、現在のノードが引数で渡されたノードの祖先であるかどうかをチェックします。
7 * DOMComment ノードは通常子ノードを持たないため、他のノードを含むことはほとんどありません。
8 * 基本的に、自分自身が引数のノードである場合にのみ true を返します。
9 */
10function demonstrateDomCommentContains(): void
11{
12    // DOMDocument オブジェクトを作成
13    $dom = new DOMDocument('1.0', 'UTF-8');
14
15    // コメントノードを作成
16    $commentNode = $dom->createComment('これはテストコメントです');
17
18    echo "--- DOMComment::contains メソッドのデモンストレーション ---\n";
19
20    // ケース1: コメントノードが自分自身を含むかチェック
21    // 任意のノードは自分自身を含むため、true が返されます。
22    echo "コメントノードが自分自身を含むか: ";
23    var_dump($commentNode->contains($commentNode));
24
25    // ケース2: コメントノードが別の DOMElement ノードを含むかチェック
26    // コメントノードは子ノードを持つことができないため、他のノードを含むことはありません。
27    // この場合、常に false が返されます。
28    $elementNode = $dom->createElement('example');
29    echo "コメントノードが別のDOMElementを含むか: ";
30    var_dump($commentNode->contains($elementNode));
31
32    // ケース3: コメントノードが null を含むかチェック
33    // null はノードではないため、含まれることはありません。
34    echo "コメントノードが null を含むか: ";
35    var_dump($commentNode->contains(null));
36}
37
38// 関数を実行して結果を表示
39demonstrateDomCommentContains();

DOMComment::containsメソッドは、PHPのDOM拡張機能において、DOMCommentクラスに属するメソッドです。このメソッドは、現在のコメントノードが引数として渡されたノードの祖先であるかどうかを真偽値(bool)で判定します。

引数$otherには、チェックしたい対象のノードとしてDOMNodeDOMNameSpaceNode、またはnullを指定できます。メソッドがtrueを返すのは、現在のノードが引数で指定されたノードと同一であるか、その親ノードである場合です。

しかし、DOMCommentノードはHTMLやXML文書内でコメントを表す特殊なノードであり、他のノードを子として持つことができません。このため、DOMComment::containsメソッドは、基本的に現在のコメントノード自身が引数として渡された場合にのみtrueを返します

サンプルコードでは、この挙動が具体的に示されています。コメントノードが自分自身を含むかをチェックした場合はtrueとなりますが、別のDOMElementノードやnullが引数として渡された場合は、コメントノードがそれらを含むことはないため、常にfalseが返されることを確認できます。このメソッドは、コメントノードの階層関係を判断する際に使用されますが、その特殊な性質を理解することが重要です。

DOMComment::containsメソッドは、現在のコメントノードが引数で渡されたノードを含んでいるかを判定します。コメントノードは通常、子ノードを持たないため、このメソッドがtrueを返すのは、引数にコメントノード自身が渡された場合に限られます。他のDOMElementのようなノードやnullを渡しても、常にfalseが返される点にご注意ください。一般的なDOMNodecontainsメソッドとは異なり、子ノードの有無を確認する用途には使えないため、その特性を理解して利用することが重要です。

関連コンテンツ

関連プログラミング言語