JavaScriptのHTMLCollectionとNodeListの違い

JavaScript Web制作

HTMLCollectionとNodeListは、どちらもDOM(Document Object Model)を操作する際に、複数の要素を取得するためにJavaScriptで利用されるオブジェクトコレクションです。しかし、それぞれの特徴や使用方法にいくつかの違いがあります。

生成される方法の違い

HTMLCollection

  • 主にdocument.getElementsByClassName()、document.getElementsByTagName()、document.formsなど、HTML要素に関連するメソッドで生成されます。
  • HTMLCollectionは、HTMLドキュメント内の特定のタグ名やクラス名に一致する要素を返すため、主にHTML特有のメソッドで使用されます。

NodeList

  • document.querySelectorAll()、document.childNodesなど、より一般的なノード(HTML要素に限らず、テキストノードやコメントノードを含む場合もあります)を扱うメソッドで生成されます。
  • NodeListは、DOM内のノードを扱うため、HTML以外の要素を含むこともあります。

動的 vs 静的

HTMLCollection

HTMLCollectionは動的(ライブ)です。HTMLドキュメントが変更されると、自動的に内容が更新されます。

例:document.getElementsByClassName("example")で取得したHTMLCollectionを使って操作する場合、ページ内の要素が変化すると(追加や削除)、コレクションの内容も自動的に更新されます。

NodeList

NodeListは静的(非ライブ)であることが一般的です。ただし、一部のブラウザやメソッドによっては動的NodeListが返される場合もあります。

例:document.querySelectorAll(".example")で取得したNodeListは静的で、後でDOMが変更されても、コレクションには反映されません。

配列のような操作の可否

HTMLCollectionとNodeListの両方は、配列のようにインデックスで要素にアクセスすることは可能ですが、完全に配列ではないため、配列のメソッドは直接利用できません。

  • HTMLCollectionにはforEach()メソッドがなく、反復処理にはforループなどが必要です。
  • NodeList(特にquerySelectorAllによって生成されたもの)はES6以降、forEach()などのメソッドを使用できますが、ブラウザ互換性により注意が必要です。
  • Array.from()を使ってHTMLCollectionやNodeListを配列に変換し、mapやfilterといった配列メソッドを使用することもできます。

要素の種類

  • HTMLCollectionは、基本的にHTML要素ノード(Elementノード)のみを保持します。
  • NodeListは、要素ノード(Elementノード)以外のノードも含めることができ、例えばテキストノードやコメントノードなども格納されることがあります。

まとめ

特徴HTMLCollectionNodeList
生成方法getElementsByClassNameなどのHTML特有メソッドで生成querySelectorAllやchildNodesなどで生成
動的 or 静的動的(ライブ)静的(一般的に非ライブ)
配列メソッドの利用直接利用不可querySelectorAllで生成された場合はforEachなどが利用可能
要素の種類HTML要素ノードのみHTML要素ノードのほか、テキストノードやコメントノードも含む場合がある

それぞれの違いを理解したうえで、適切な場面でHTMLCollectionまたはNodeListを使い分けると、より効果的なDOM操作が可能です。

HTMLCollection - Web API | MDN
HTMLCollection インターフェイスは、(文書内の順序における)要素の汎用的な集合(arguments のような配列風のオブジェクト)を表し、リストから選択するためのメソッドとプロパティを提供します。
NodeList - Web API | MDN
NodeList オブジェクトはノードの集合であり、 Node.childNodes などのプロパティや document.querySelectorAll() などのメソッドの返値として用いられます。
タイトルとURLをコピーしました