はじめに
この記事では、JavaScript の要素セレクタにおける Live NodeList と Static NodeList の違いについて解説する。
この記事では、JavaScript の要素セレクタにおける Live NodeList と Static NodeList の違いについて解説する。
要素セレクタは、HTML ドキュメント内の要素を選択するために使用される関数である。JavaScript には、さまざまな要素セレクタが用意されており、それらを使って HTML 要素にアクセスして操作できる。
Live NodeList は、HTML ドキュメント内の要素のリストを表すオブジェクトで、そのリストが動的に更新されることが特徴である。つまり、元の HTML ドキュメントが変更されると、Live NodeList も自動的に更新される。
Static NodeList は、Live NodeList と同様に、HTML ドキュメント内の要素のリストを表すオブジェクトであるが、一度生成された後は更新されない。そのため、元の HTML ドキュメントが変更されても、Static NodeList の内容は変わらない。
Live NodeList は、元の HTML ドキュメントが変更されると自動的に更新されるが、Static NodeList は一度生成された後は更新されない。これが両者の最も大きな違いである。
Live NodeList は動的に更新されるため、パフォーマンス面で Static NodeList よりも劣る場合がある。特に、大量の要素を扱う場合や頻繁に DOM が更新される場合には、Live NodeList のパフォーマンスが影響を受けることがある。対して、Static NodeList は更新されないため、パフォーマンス面での影響は少ない。
Live NodeList と Static NodeList は、それぞれ異なる関数を使って生成される。後述する各関数を使って、適切なリストを選択して利用することが大切である。
getElementsByClassName
は、指定したクラス名を持つ要素をすべて取得し、Live NodeList を返す関数である。以下のように使用する。
const liveNodeList = document.getElementsByClassName('example');
childNodes
は、ある要素の子要素をすべて取得し、Live NodeList を返すプロパティである。以下のように使用する。
const liveNodeList = element.childNodes;
getElementsByClassName
以外にも、以下のような Live NodeList を生成するメソッドがある。
getElementsByTagName
: 指定したタグ名を持つ要素をすべて取得し、Live NodeList を返す関数getElementsByName
: 指定した name 属性を持つ要素をすべて取得し、Live NodeList を返す関数querySelectorAll
は、指定したセレクタにマッチする要素をすべて取得し、Static NodeList を返す関数である。以下のように使用する。
const staticNodeList = document.querySelectorAll('.example');
querySelectorAll
以外にも、以下のような Static NodeList を生成するメソッドがある。
getElementsByTagName
getElementsByName
メソッド | 返却するオブジェクト | Static / Live NodeList |
---|---|---|
querySelector | HTMLElement | Static |
querySelectorAll | NodeList | Static |
getElementById | HTMLElement | Static |
getElementsByTagName | HTMLCollection | Live |
getElementsByClassName | HTMLCollection | Live |
※ querySelector
とgetElementById
は単一のHTMLElement
を返すため、厳密にはNodeList
ではないが、Static として扱われる。
Live NodeList と Static NodeList のどちらを選択するかは、ユースケースによって異なる。
DOM が更新されることが予想される場合や常に最新の要素を取得したい場合には、Live NodeList を使用することが適切である。一方、一度取得した要素を固定したい場合やパフォーマンスを重視する場合には、Static NodeList を使用することが適切である。
前述の通り、Live NodeList はパフォーマンス面で劣ることがあるため、必要に応じて Static NodeList を選択することが望ましいである。また、一部の関数やプロパティは、古いブラウザではサポートされていないことがあるため、互換性も考慮する必要がある。
JavaScript の要素セレクタにおける Live NodeList と Static NodeList は、それぞれ異なる特徴と利点がある。適切なリストを選択して利用することで、効率的に DOM 操作できる。