声明! ! , この記事は他の人の記事の転載です。たまたま使用されていて非常に実用的だと感じたので、今後の使用のために取り上げました。 !
原作者さんに感謝です! ! ! 、
Web アプリケーション、特に Web 2.0 プログラムの開発では、多くの場合、ページ内の要素を取得し、要素のスタイル、コンテンツなどを更新する必要があります。更新する要素をどのように取得するかが最初に解決すべき問題です。幸いなことに、JavaScript を使用してノードを取得する方法は数多くあります。簡単にまとめます (次の方法は IE7 と Firefox2.0.0.11 でテストされています)。
1. 最上位のドキュメント ノードから取得します。
(1) document.getElementById(elementId): このメソッドは、ノードの ID を通じて必要な要素を正確に取得できます。比較的単純で高速なメソッドです。ページに同じ ID を持つ複数のノードが含まれている場合は、最初のノードのみが返されます。
現在では、プロトタイプや Mootools など、より単純なメソッド $(id) を提供する JavaScript ライブラリが多数あり、パラメータは依然としてノードの ID です。このメソッドは document.getElementById() の別の記述方法とみなすことができますが、$() の関数の方が強力です。具体的な使用方法については、それぞれの API ドキュメントを参照してください。
(2) document.getElementsByName(elementName): このメソッドは、名前からわかるように、ノード要素ではなく、同じ名前を持つノードの配列を返します。次に、ノードの特定の属性をループして、それが必要なノードであるかどうかを判断します。
例: HTML では、チェックボックスとラジオはどちらも同じ name 属性値を使用して、グループ内の要素を識別します。選択した要素を今すぐ取得したい場合は、まずシャッフルされた要素を取得し、次にループしてノードのチェックされた属性値が true かどうかを判断します。
(3) document.getElementsByTagName(tagName): このメソッドは、タグを通じてノードを取得します。例: document.getElementsByTagName('A') は、ページ上のすべてのハイパーリンク ノードを返します。ノードを取得する前に、ノードのタイプは一般にわかっているため、この方法を使用するのは比較的簡単です。しかし、欠点も明らかです。それは、返される配列が非常に大きくなる可能性があり、多くの時間を無駄にすることです。では、この方法は無駄なのでしょうか?もちろん、この方法は上記の 2 つとは異なります。これはドキュメント ノード独自の方法ではなく、後述する他のノードにも適用できます。
2. 親ノードを通じて取得します。
(1)parentObj.firstChild: このメソッドは、ノードが既知のノード (parentObj) の最初の子ノードである場合に使用できます。この属性は再帰的に使用できます。つまり、parentObj.firstChild.firstChild.firstChild... の形式をサポートしているため、より深いノードを取得できます。
(2)parentObj.lastChild: 明らかに、この属性は既知のノード (parentObj) の最後の子ノードを取得するためのものです。 firstChild と同様に、再帰的に使用することもできます。
使用中に、この 2 つを組み合わせると、より興味深い結果が得られます。つまり、parentObj.firstChild.lastChild.lastChild... です。
(3)parentObj.childNodes: 既知のノードの子ノード配列を取得し、ループまたはインデックス作成を通じて必要なノードを見つけます。
注: テストの結果、IE7 では直接の子ノードの配列が取得されるのに対し、Firefox2.0.0.11 では子ノードの子ノードを含むすべての子ノードが取得されることがわかりました。
(4)parentObj.children: 既知のノードの直接の子ノード配列を取得します。
注: テスト後、IE7 では効果は childNodes と同じですが、Firefox2.0.0.11 ではサポートされていません。これが、私が他の方法とは異なるスタイルを使用する理由です。したがって、その使用はお勧めできません。
(5)parentObj.getElementsByTagName(tagName): 使用方法については詳細は説明しません。既知のノードのすべての子ノードのうち、指定された値の子ノードの配列を返します。例:parentObj.getElementsByTagName('A') は、既知の子ノード内のすべてのハイパーリンクを返します。
3. 隣接ノードから取得します。
(1)neighborNode.previousSibling: 既知のノード(neighbourNode)の前のノードを取得します。この属性は前のfirstChildやlastChildと同様に再帰的に使用されるようです。
(2) neighborsNode.nextSibling: 既知のノード (neighbourNode) の次のノードを取得します。再帰もサポートします。
4. 子ノードを通じて取得します。
(1) childNode.parentNode: 既知のノードの親ノードを取得します。
上記のメソッドはほんの一部の基本的なメソッドです。Prototype などの JavaScript ライブラリを使用する場合は、ノードのクラスを介して取得するなど、他の異なるメソッドを取得することもできます。しかし、上記のさまざまな方法を柔軟に使いこなすことができれば、ほとんどのプログラムには対応できると思います。
これは再作成されたドキュメントであることに注意してください。firstChild および lastChild を通じて HTML ノードを取得することはお勧めできません。ブラウザによっては、firstChild がparentObj の属性オブジェクトを返す場合があるためです。