diff options
author | Masahiro FUJIMOTO <mfujimot@gmail.com> | 2022-02-25 01:16:29 +0900 |
---|---|---|
committer | Masahiro FUJIMOTO <mfujimot@gmail.com> | 2022-03-04 00:10:29 +0900 |
commit | ae2d52b90b77c3280f4af75596c38f41c7c5cc8f (patch) | |
tree | f194f8e685dc0a63484a2f94fb7e56681637df91 /files/ja/web/api | |
parent | 6b5ccdd555c3222da227d9ae9d5aa6cd0cc1caa5 (diff) | |
download | translated-content-ae2d52b90b77c3280f4af75596c38f41c7c5cc8f.tar.gz translated-content-ae2d52b90b77c3280f4af75596c38f41c7c5cc8f.tar.bz2 translated-content-ae2d52b90b77c3280f4af75596c38f41c7c5cc8f.zip |
2021/11/13 時点の英語版に同期
Diffstat (limited to 'files/ja/web/api')
-rw-r--r-- | files/ja/web/api/node/index.md | 454 |
1 files changed, 176 insertions, 278 deletions
diff --git a/files/ja/web/api/node/index.md b/files/ja/web/api/node/index.md index dc20596b32..09dbc6a8bd 100644 --- a/files/ja/web/api/node/index.md +++ b/files/ja/web/api/node/index.md @@ -2,317 +2,215 @@ title: Node slug: Web/API/Node tags: - - API - - DOM - - Document - - Element - - Interface - - Node - - Reference - - Structure - - hierarchy -translation_of: Web/API/Node + - インターフェイス + - リファレンス browser-compat: api.Node +translation_of: Web/API/Node --- -<p>{{APIRef("DOM")}}</p> - -<p>{{Glossary("DOM")}} の <strong><code>Node</code></strong> インターフェイスは、他の多くの DOM API オブジェクトのベースとなる抽象的な基底クラスです。したがって、これらのオブジェクト型と類似しており、しばしば交換して使用することができます。抽象クラスであるため、単なる <code>Node</code> オブジェクトというものは存在しません。 <code>Node</code> の機能を実装しているオブジェクトはすべて、そのサブクラスの一つをベースにしています。最も注目すべきものは、 {{domxref("Document")}}, {{domxref("Element")}}, {{domxref("DocumentFragment")}} です。</p> - -<p>それに加えて、あらゆる種類の DOM ノードが <code>Node</code> を基底とするインターフェイスで表現されます。これには、 {{DOMxRef("Attr")}}, {{DOMxRef("CharacterData")}} - ({{DOMxRef("Text")}}, {{DOMxRef("Comment")}}, {{DOMxRef("CDATASection")}}, {{DOMxRef("ProcessingInstruction")}} がすべて既定とするもの), {{DOMxRef("DocumentType")}}, {{DOMxRef("Notation")}}, {{DOMxRef("Entity")}}, {{DOMxRef("EntityReference")}} があります。</p> - -<p>場合によっては、ベースとなる <code>Node</code> インターフェイスの特定の機能が子インターフェイスに適用されないことがあります。この場合、継承するノードは状況に応じて <code>null</code> を返したり、例外を投げたりします。例えば、子を持てないノード型に子を追加しようとすると、例外が発生します。</p> - -<p>{{InheritanceDiagram}}</p> - -<h2 id="Properties">プロパティ</h2> - -<p><em>以下のプロパティに加え、 <code>Node</code> は親である {{DOMxRef("EventTarget")}} からプロパティを継承しています</em>。</p> - -<dl> - <dt>{{DOMxRef("Node.baseURI")}}{{ReadOnlyInline}}</dt> - <dd>この <code>Node</code> を持つ文書のベース URL を表す {{DOMxRef("DOMString")}} を返します。</dd> - <dt>{{DOMxRef("Node.childNodes")}}{{ReadOnlyInline}}</dt> - <dd>このノードのすべての子孫 (要素、テキスト、コメント) を持つ、生きた {{DOMxRef("NodeList")}} を返します。 {{DOMxRef("NodeList")}} が生きているとは、<code>Node</code> の子が変化すれば自動的に {{DOMxRef("NodeList")}} オブジェクトが更新されることを意味します。</dd> - <dt>{{DOMxRef("Node.firstChild")}}{{ReadOnlyInline}}</dt> - <dd>ノードの直下の最初の子ノードを表す {{DOMxRef("Node")}} を返します。子が存在しなければ <code>null</code> を返します。</dd> - <dt>{{DOMxRef("Node.isConnected")}}{{ReadOnlyInline}}</dt> - <dd>論理値で、ノードが (直接/間接的に) コンテキストオブジェクト、例えば、通常の DOM の場合は {{DOMxRef("Document")}} オブジェクト、あるいはシャドー DOM の場合は {{DOMxRef("ShadowRoot")}} に接続されているかどうかを示します。</dd> - <dt>{{DOMxRef("Node.lastChild")}}{{ReadOnlyInline}}</dt> - <dd>ノードの直下の最後の子ノードを表す {{DOMxRef("Node")}} を返します。子が存在しなければ <code>null</code> を返します。</dd> - <dt>{{DOMxRef("Node.nextSibling")}}{{ReadOnlyInline}}</dt> - <dd>ツリー構造で次のノードを表す {{DOMxRef("Node")}} を返します。該当するノードがない場合は <code>null</code> を返します。</dd> - <dt>{{DOMxRef("Node.nodeName")}}{{ReadOnlyInline}}</dt> - <dd><code>Node</code> の名前を持つ {{DOMxRef("DOMString")}} を返します。名前の構造は、ノードの型によって異なります。例えば、{{DOMxRef("HTMLElement")}} は {{DOMxRef("HTMLAudioElement")}} に対して <code>'audio'</code> というように対応するタグの名前、{{DOMxRef("Text")}} ノードは <code>'#text'</code> という文字列、{{DOMxRef("Document")}} ノードは <code>'#document'</code> という文字列になります。</dd> - <dt>{{DOMxRef("Node.nodeType")}}{{ReadOnlyInline}}</dt> - <dd>ノードの型を表す <code>unsigned short</code> を返します。使用できる値は次の通りです。 - <table class="standard-table"> - <thead> - <tr> - <th scope="col">名称</th> - <th scope="col">値</th> - </tr> - </thead> - <tbody> - <tr> - <td><code>ELEMENT_NODE</code></td> - <td><code>1</code></td> - </tr> - <tr> - <td><code>ATTRIBUTE_NODE</code> {{Deprecated_Inline}}</td> - <td><code>2</code></td> - </tr> - <tr> - <td><code>TEXT_NODE</code></td> - <td><code>3</code></td> - </tr> - <tr> - <td><code>CDATA_SECTION_NODE</code></td> - <td><code>4</code></td> - </tr> - <tr> - <td><code>ENTITY_REFERENCE_NODE</code> {{Deprecated_Inline}}</td> - <td><code>5</code></td> - </tr> - <tr> - <td><code>ENTITY_NODE</code> {{Deprecated_Inline}}</td> - <td><code>6</code></td> - </tr> - <tr> - <td><code>PROCESSING_INSTRUCTION_NODE</code></td> - <td><code>7</code></td> - </tr> - <tr> - <td><code>COMMENT_NODE</code></td> - <td><code>8</code></td> - </tr> - <tr> - <td><code>DOCUMENT_NODE</code></td> - <td><code>9</code></td> - </tr> - <tr> - <td><code>DOCUMENT_TYPE_NODE</code></td> - <td><code>10</code></td> - </tr> - <tr> - <td><code>DOCUMENT_FRAGMENT_NODE</code></td> - <td><code>11</code></td> - </tr> - <tr> - <td><code>NOTATION_NODE</code> {{Deprecated_Inline}}</td> - <td><code>12</code></td> - </tr> - </tbody> - </table> - </dd> - <dt>{{DOMxRef("Node.nodeValue")}}</dt> - <dd>現在のノードの値を取得または設定します。</dd> - <dt>{{DOMxRef("Node.ownerDocument")}}{{ReadOnlyInline}}</dt> - <dd>ノードが所属する {{DOMxRef("Document")}} を返します。ノードが document 自身の場合は、<code>null</code> を返します。</dd> - <dt>{{DOMxRef("Node.parentNode")}}{{ReadOnlyInline}}</dt> - <dd>このノードの親の {{DOMxRef("Node")}} を返します。ノードがツリーの最上位である、あるいはツリーに加わっていないなど、親が存在しない場合は <code>null</code> を返します。</dd> - <dt>{{DOMxRef("Node.parentElement")}}{{ReadOnlyInline}}</dt> - <dd>このノードの親の {{DOMxRef("Element")}} を返します。ノードに親が存在しない、あるいは親が {{DOMxRef("Element")}} ではない場合は、<code>null</code> を返します。</dd> - <dt>{{DOMxRef("Node.previousSibling")}}{{ReadOnlyInline}}</dt> - <dd>ツリー構造で前のノードを表す {{DOMxRef("Node")}} を返します。該当するノードがない場合は <code>null</code> を返します。</dd> - <dt>{{DOMxRef("Node.textContent")}}</dt> - <dd>要素や要素のすべての子孫のテキストコンテンツを取得または設定します。</dd> -</dl> - -<h2 id="Methods">メソッド</h2> - -<p><em>以下のプロパティに加えて、親である {{DOMxRef("EventTarget")}} からメソッドを継承しています。</em></p> - -<dl> - <dt>{{DOMxRef("Node.appendChild()", "Node.appendChild(<var>childNode</var>)")}}</dt> - <dd>現在のノードの最後の子として、指定した childNode 引数を追加します。<br> - 引数が DOM ツリー上の既存のノードを参照している場合は、ノードが現在の位置から外されて新しい位置に追加されます。</dd> - <dt>{{DOMxRef("Node.cloneNode()")}}</dt> - <dd>{{DOMxRef("Node")}} を複製します。また、すべての内容物を複製することもできます。既定で、ノードの内容物を複製します。</dd> - <dt>{{DOMxRef("Node.compareDocumentPosition()")}}</dt> - <dd>現在のノードの位置を、他のドキュメント内の別のノードと比較します。</dd> - <dt>{{DOMxRef("Node.contains()")}}</dt> - <dd>ノードが指定したノードの子孫であるか否かを <code>true</code> または <code>false</code> の値で返します。</dd> - <dt>{{domxref("Node.getBoxQuads()")}} {{experimental_inline}}</dt> - <dd>このノードの CSS ボックスのうち、他のノードに関連するもののリストを返します。</dd> - <dt>{{DOMxRef("Node.getRootNode()")}}</dt> - <dd>コンテキストオブジェクトのルートを返します。任意で、シャドウルートが使用可能である場合にそれを含めることができます。</dd> - <dt>{{DOMxRef("Node.hasChildNodes()")}}</dt> - <dd>要素が子ノードを持っているか否かを示す {{jsxref("Boolean")}} を返します。</dd> - <dt>{{DOMxRef("Node.insertBefore()")}}</dt> - <dd>現在のノードの子として、参照先ノードの前に {{DOMxRef("Node")}} を挿入します。</dd> - <dt>{{DOMxRef("Node.isDefaultNamespace()")}}</dt> - <dd>引数として名前空間の URI を受け入れて、名前空間が指定したノードのデフォルトの名前空間であれば <code>true</code>、そうでない場合は <code>false</code> である {{jsxref("Boolean")}} を返します。</dd> - <dt>{{DOMxRef("Node.isEqualNode()")}}</dt> - <dd>2 つのノードが同じ型であり、定義されているすべてのデータポイントが一致するか否かを表す {{jsxref("Boolean")}}を返します。</dd> - <dt>{{DOMxRef("Node.isSameNode()")}}</dt> - <dd>2 つのノードが同じである (すなわち、同じオブジェクトを参照している) か否かを示す {{jsxref("Boolean")}} 値を返します。</dd> - <dt>{{DOMxRef("Node.lookupPrefix()")}}</dt> - <dd>指定した名前空間 URI の接頭辞があれば、その接頭辞を含む {{DOMxRef("DOMString")}} を返します。接頭辞がない場合は <code>null</code> を返します。複数の接頭辞があった場合の結果は実装依存です。</dd> - <dt>{{DOMxRef("Node.lookupNamespaceURI()")}}</dt> - <dd>接頭辞を受け入れて、指定したノードで接頭辞が関連付けられた名前空間が見つかった場合は名前空間の URI を返します (見つからない場合は <code>null</code> を返します)。接頭辞として <code>null</code> を与えると、デフォルトの名前空間を返します。</dd> - <dt>{{DOMxRef("Node.normalize()")}}</dt> - <dd>要素内のすべてのテキストノードをクリーンアップ (隣接ノードを統合、空のノードを削除) します。</dd> - <dt>{{DOMxRef("Node.removeChild()")}}</dt> - <dd>現在の要素から子ノードを削除します。現在の要素は現在のノードの子であることが必要です。</dd> - <dt>{{DOMxRef("Node.replaceChild()")}}</dt> - <dd>現在のノードの子 {{DOMxRef("Node")}} のひとつを、引数で指定した別のノードで置き換えます。</dd> -</dl> - -<h3 id="Obsolete_methods">廃止メソッド</h3> - -<dl> - <dt>{{DOMxRef("Node.hasAttributes()")}} {{deprecated_inline}}</dt> - <dd>要素がなんらかの属性を持っているか否かを <code>true</code> または <code>false</code> で返します。</dd> - <dt>{{DOMxRef("Node.isSupported()")}} {{deprecated_inline}}</dt> - <dd>DOM 実装が特定の機能を実装しており、またその機能が指定したノードでサポートされているかを確認して、その結果を <code>true</code> または <code>false</code> で返します。</dd> -</dl> - -<h2 id="Examples">例</h2> - -<h3 id="Remove_all_children_nested_within_a_node">ノード内にあるすべての子を削除 -</h3> - -<pre class="brush: js">function removeAllChildren(element) { +{{APIRef("DOM")}} + +{{Glossary("DOM")}} の **`Node`** インターフェイスは、他の多くの DOM API オブジェクトのベースとなる抽象的な基底クラスです。したがって、これらのオブジェクト型と類似しており、しばしば交換して使用することができます。抽象クラスであるため、単なる `Node` オブジェクトというものは存在しません。 `Node` の機能を実装しているオブジェクトはすべて、何れかのサブクラスに基づいています。最も注目すべきものは、 {{domxref("Document")}}, {{domxref("Element")}}, {{domxref("DocumentFragment")}} です。 + +それに加えて、あらゆる種類の DOM ノードが `Node` を基底とするインターフェイスで表現されます。これには、 {{DOMxRef("Attr")}}, {{DOMxRef("CharacterData")}} ({{DOMxRef("Text")}}, {{DOMxRef("Comment")}}, {{DOMxRef("CDATASection")}}, {{DOMxRef("ProcessingInstruction")}} がすべて基底とするもの), {{DOMxRef("DocumentType")}} があります。 + +場合によっては、ベースとなる `Node` インターフェイスの特定の機能が子インターフェイスに適用されないことがあります。この場合、継承するノードは状況に応じて `null` を返したり、例外を投げたりします。例えば、子を持てないノード型に子を追加しようとすると、例外が発生します。 + +{{InheritanceDiagram}} + +## プロパティ + +_以下のプロパティに加え、 `Node` は親である {{DOMxRef("EventTarget")}} からプロパティを継承しています_。 + +- {{DOMxRef("Node.baseURI")}}{{ReadOnlyInline}} + - : この `Node` を持つ文書のベース URL を表す文字列を返します。 +- {{DOMxRef("Node.childNodes")}}{{ReadOnlyInline}} + - : このノードのすべての子孫(要素、テキスト、コメント)を持つ、生きた {{DOMxRef("NodeList")}} を返します。 {{DOMxRef("NodeList")}} が生きているとは、`Node` の子が変化すれば自動的に {{DOMxRef("NodeList")}} オブジェクトが更新されることを意味します。 +- {{DOMxRef("Node.firstChild")}}{{ReadOnlyInline}} + - : ノードの直下の最初の子ノードを表す `Node` を返します。子が存在しなければ `null` を返します。 +- {{DOMxRef("Node.isConnected")}}{{ReadOnlyInline}} + - : 論理値で、ノードが (直接/間接的に) コンテキストオブジェクト、例えば、通常の DOM の場合は {{DOMxRef("Document")}} オブジェクト、あるいはシャドー DOM の場合は {{DOMxRef("ShadowRoot")}} に接続されているかどうかを示します。 +- {{DOMxRef("Node.lastChild")}}{{ReadOnlyInline}} + - : ノードの直下の最後の子ノードを表す `Node` を返します。子が存在しなければ `null` を返します。 +- {{DOMxRef("Node.nextSibling")}}{{ReadOnlyInline}} + - : ツリー構造で次のノードを表す `Node` を返します。該当するノードがない場合は `null` を返します。 +- {{DOMxRef("Node.nodeName")}}{{ReadOnlyInline}} + - : `Node` の名前を持つ文字列を返します。名前の構造は、ノードの型によって異なります。例えば、{{DOMxRef("HTMLElement")}} は {{DOMxRef("HTMLAudioElement")}} に対して `'audio'` というように対応するタグの名前、 {{DOMxRef("Text")}} ノードは `'#text'` という文字列、 {{DOMxRef("Document")}} ノードは `'#document'` という文字列になります。 +- {{DOMxRef("Node.nodeType")}}{{ReadOnlyInline}} + - : ノードの型を表す `unsigned short` を返します。使用できる値は次の通りです。 + + | 名前 | 値 | + | ---------------------------------------------------- | ----- | + | `ELEMENT_NODE` | `1` | + | `ATTRIBUTE_NODE` | `2` | + | `TEXT_NODE` | `3` | + | `CDATA_SECTION_NODE` | `4` | + | `PROCESSING_INSTRUCTION_NODE` | `7` | + | `COMMENT_NODE` | `8` | + | `DOCUMENT_NODE` | `9` | + | `DOCUMENT_TYPE_NODE` | `10` | + | `DOCUMENT_FRAGMENT_NODE` | `11` | + +- {{DOMxRef("Node.nodeValue")}} + - : 現在のノードの値を取得または設定します。 +- {{DOMxRef("Node.ownerDocument")}}{{ReadOnlyInline}} + - : ノードが所属する文書を {{DOMxRef("Document")}} で返します。ノードが文書自身の場合は、`null` を返します。 +- {{DOMxRef("Node.parentNode")}}{{ReadOnlyInline}} + - : このノードの親の `Node` を返します。ノードがツリーの最上位である、あるいはツリーに加わっていないなど、親が存在しない場合は `null` を返します。 +- {{DOMxRef("Node.parentElement")}}{{ReadOnlyInline}} + - : このノードの親の要素を {{DOMxRef("Element")}} で返します。ノードに親が存在しない、あるいは親が {{DOMxRef("Element")}} ではない場合は、`null` を返します。 +- {{DOMxRef("Node.previousSibling")}}{{ReadOnlyInline}} + - : ツリー構造で前のノードを表す `Node` を返します。該当するノードがない場合は `null` を返します。 +- {{DOMxRef("Node.textContent")}} + - : 要素や要素のすべての子孫のテキストコンテンツを取得または設定します。 + +## メソッド + +_以下のプロパティに加えて、親である {{DOMxRef("EventTarget")}} からメソッドを継承しています。_ + +- {{DOMxRef("Node.appendChild()")}} + - : 指定された `childNode` 引数を、現在のノードの最後の子として追加します。 + 引数が DOM ツリー上の既存のノードを参照している場合は、ノードが現在の位置から外されて新しい位置に追加されます。 +- {{DOMxRef("Node.cloneNode()")}} + - : `Node` を複製します。また、すべての内容物を複製することもできます。既定で、ノードの内容物を複製します。 +- {{DOMxRef("Node.compareDocumentPosition()")}} + - : 現在のノードの位置を、他の文書内の別のノードと比較します。 +- {{DOMxRef("Node.contains()")}} + - : ノードが指定したノードの子孫であるか否かを `true` または `false` の値で返します。 +- {{DOMxRef("Node.getRootNode()")}} + - : コンテキストオブジェクトのルートを返します。任意で、シャドウルートが使用可能である場合にそれを含めることができます。 +- {{DOMxRef("Node.hasChildNodes()")}} + - : 要素が子ノードを持っているか否かを示す論理値を返します。 +- {{DOMxRef("Node.insertBefore()")}} + - : 現在のノードの子として、参照先ノードの前に `Node` を挿入します。 +- {{DOMxRef("Node.isDefaultNamespace()")}} + - : 引数として名前空間の URI を受け入れて、名前空間が指定したノードの既定の名前空間であれば `true`、そうでない場合は `false` である論理値を返します。 +- {{DOMxRef("Node.isEqualNode()")}} + - : 2 つのノードが同じ型であり、定義されているすべてのデータポイントが一致するか否かを表す 論理値を返します。 +- {{DOMxRef("Node.isSameNode()")}} + - : 2 つのノードが同じである (すなわち、同じオブジェクトを参照している) か否かを示す論理値値を返します。 +- {{DOMxRef("Node.lookupPrefix()")}} + - : 指定した名前空間 URI の接頭辞があれば、その接頭辞を含む {{DOMxRef("DOMString")}} を返します。接頭辞がない場合は `null` を返します。複数の接頭辞があった場合の結果は実装依存です。 +- {{DOMxRef("Node.lookupNamespaceURI()")}} + - : 接頭辞を受け入れて、指定したノードで接頭辞が関連付けられた名前空間が見つかった場合は名前空間の URI を返します (見つからない場合は `null` を返します)。接頭辞として `null` を与えると、既定の名前空間を返します。 +- {{DOMxRef("Node.normalize()")}} + - : 要素内のすべてのテキストノードをクリーンアップ(隣接ノードを統合し、空のノードを削除)します。 +- {{DOMxRef("Node.removeChild()")}} + - : 現在の要素から子ノードを削除します。現在の要素は現在のノードの子であることが必要です。 +- {{DOMxRef("Node.replaceChild()")}} + - : 現在のノードの子 `Node` のひとつを、引数で指定した別のノードで置き換えます。 + +### 廃止されたメソッド + +- {{DOMxRef("Node.isSupported()")}} {{deprecated_inline}} + - : DOM 実装が特定の機能を実装しており、またその機能が指定したノードで対応しているかを確認して、その結果を `true` または `false` で返します。 + +## 例 + +### ノード内にあるすべての子を削除 + +この関数は、ある要素の最初の子を、一つも残らなくなるまで削除します。 + +```js +function removeAllChildren(element) { while (element.firstChild) { element.removeChild(element.firstChild) } -}</pre> - -<h4 id="Sample_usage">単純な使用方法</h4> - -<pre class="brush: js">/* Note: or use document.body.textContent = "" */ -removeAllChildren(document.body)</pre> - -<h3 id="Recurse_through_child_nodes">すべての子ノードを走査する</h3> - -<p>次の関数は、ルートノードに含まれる (ルートノード自身も含めた) すべてのノードに対してコールバック関数を再帰的に呼び出します。</p> - -<pre class="brush: js">function eachNode(rootNode, callback) { - if (!callback) { - const nodes = [] - eachNode(rootNode, function(node) { - nodes.push(node) - }) - return nodes - } - - if (false === callback(rootNode)) { - return false - } - - if (rootNode.hasChildNodes()) { - const nodes = rootNode.childNodes - for (let i = 0, l = nodes.length; i < l; ++i) { - if (false === eachNode(nodes[i], callback)) { - return - } - } - } } -</pre> - -<h4 id="Syntax">構文</h4> - -<pre - class="brush: js">eachNode(<var>rootNode</var>, <var>callback</var>)</pre> - -<h4 id="Description">解説</h4> - -<p><code><var>rootNode</var></code> の (ルート自身を含む) 各子孫ノードに対して、関数を再帰的に呼び出します。</p> +``` -<p><code><var>callback</var></code> -が省略された場合、この関数は代わりに {{jsxref("Array")}} を返し、そこには <code><var>rootNode</var></code> とその中に含まれるすべてのノードが含まれます。</p> +この関数の使用は単一の呼び出しです。こちらでは、文書の本文を空にします。 -<p><code><var>callback</var></code> が提供され、 <code>false</code> を返した場合、現在の再帰レベルは中止され、関数は最後の親のレベルから実行を再開します。これは、 (特定の文字列を含むテキストノードを検索するなどして) ノードが見つかった時点でループを中止するために利用できます。 -</p> +```js +removeAllChildren(document.body) +``` -<h4 id="Parameters">引数</h4> +他の方法として、 textContent に空文字列を設定すること (`document.body.textContent = ""`) も可能です。 -<dl> - <dt><code><var>rootNode</var></code></dt> - <dd>再帰的に子孫の走査を行う <code>Node</code> オブジェクトです。</dd> - <dt><code><var>callback</var></code> {{optional_inline}}</dt> - <dd>省略可能なコールバック<a - href="/ja/docs/Web/JavaScript/Reference/Global_Objects/Function">関数</a>で、単一の <code>Node</code> を引数として受け取るものです。省略された場合、 <code>eachNode</code> は {{jsxref("Array")}} で、 <code><var>rootNode</var></code> の中に含まれる (ルート自身も含む) ノードの一覧を返します。</dd> -</dl> +### すべての子ノードの走査 -<h4 id="Sample_usage_2">単純な使用</h4> +次の関数は、ルートノードに含まれる(ルートノード自身も含めた)すべてのノードに対してコールバック関数を再帰的に呼び出します。 -<p>以下の例は、<code>"box"</code> という名前の <code><div></code> 要素の中にあるそれぞれの <code><span></code> 要素の <a href="/ja/docs/Web/API/Node/textContent"><code>textContent</code></a> プロパティを出力します。</p> +```js +function eachNode(rootNode, callback) { + if (!callback) { + const nodes = [] + eachNode(rootNode, function(node) { + nodes.push(node) + }) + return nodes + } -<pre class="brush: html"><div id="box"> - <span>Foo</span> - <span>Bar</span> - <span>Baz</span> -</div></pre> + if (false === callback(rootNode)) { + return false + } -<pre class="brush: js">const box = document.getElementById("box") -eachNode(box, function(node) { - if (null != node.textContent) { - console.log(node.textContent) + if (rootNode.hasChildNodes()) { + const nodes = rootNode.childNodes + for (let i = 0, l = nodes.length; i < l; ++i) { + if (false === eachNode(nodes[i], callback)) { + return + } + } } -})</pre> +} +``` + +この関数は、 `rootNode` のそれぞれの子孫ノードに対して(ルート自身も含め)再帰的に関数を呼び出します。 -<p>上記の例は、ユーザーのコンソールに以下の文字列を結果として出力します。</p> +`callback` が省略された場合、この関数は代わりに {{jsxref("Array")}} を返し、そこには `rootNode` とその中に含まれるすべてのノードが含まれます。 -<pre class="brush: js">"\n\t", "Foo", "\n\t", "Bar", "\n\t", "Baz"</pre> +`callback` が提供され、 `false` を返した場合、現在の再帰レベルは中止され、関数は最後の親のレベルから実行を再開します。これは、(特定の文字列を含むテキストノードを検索するなどして)ノードが見つかった時点でループを中止するために利用できます。 -<div class="notecard note"> - <p><strong>注:</strong> ホワイトスペースは {{DOMxRef("Text")}} ノードの一部を形成し、インデントと改行は独立した <code>Text</code> を <code>Element</code> ノードの間に形成します。</p> -</div> +この関数には 2 つの引数があります。 -<h4 id="Realistic_usage">実際の使い方</h4> +- `rootNode` + - : 再帰的に子孫の走査を行う `Node` オブジェクトです。 +- `callback` {{optional_inline}} + - : 省略可能なコールバック[関数](/ja/docs/Web/JavaScript/Reference/Global_Objects/Function)で、単一の `Node` を引数として受け取るものです。省略された場合、 `eachNode` は {{jsxref("Array")}} で、 `rootNode` の中に含まれる (ルート自身も含む) ノードの一覧を返します。 -<p>次の例は <code>eachNode()</code> 関数の現実世界での使用方法として、ウェブページ上のテキストの検索を示します。</p> +次の例は `eachNode()` 関数の現実世界での使用方法として、ウェブページ上のテキストの検索を示します。 -<p>検索には <code>grep</code> というラッパー関数を使用しています。</p> +検索には `grep` というラッパー関数を使用しています。 -<pre class="brush: js">function grep(parentNode, pattern) { - const matches = [] - let endScan = false +```js +function grep(parentNode, pattern) { + const matches = [] + let endScan = false - eachNode(parentNode, function(node){ - if (endScan) { - return false + eachNode(parentNode, function(node){ + if (endScan) { + return false } - // Ignore anything which isn't a text node - if (node.nodeType !== Node.TEXT_NODE) { - return + // Ignore anything which isn't a text node + if (node.nodeType !== Node.TEXT_NODE) { + return } - if (typeof pattern === "string") { - if (-1 !== node.textContent.indexOf(pattern)) { - matches.push(node) + if (typeof pattern === "string") { + if (-1 !== node.textContent.indexOf(pattern)) { + matches.push(node) } - } - else if (pattern.test(node.textContent)) { - if (!pattern.global) { - endScan = true - matches = node - } - else { + } + else if (pattern.test(node.textContent)) { + if (!pattern.global) { + endScan = true + matches = node + } + else { matches.push(node) } - } - }) - - return matches -}</pre> - -<p>For example, to find {{DOMxRef("Text")}} nodes that contain typos:</p> + } + }) -<pre class="brush: js">const typos = ["teh", "adn", "btu", "adress", "youre", "msitakes"] -const pattern = new RegExp("\\b(" + typos.join("|") + ")\\b", "gi") -const mistakes = grep(document.body, pattern) -console.log(mistakes) -</pre> + return matches +} +``` -<h2 id="Specifications">仕様書</h2> +## 仕様書 {{Specifications}} -<h2 id="Browser_compatibility">ブラウザーの互換性</h2> +## ブラウザーの互換性 -<p>{{Compat}}</p> +{{Compat}} |