Loading Please Wait...

Logo Lynxsia IT Solutions

JavaScript HTML DOM Node Lists

JS HTML DOM Node Lists

A NodeList object is a list (collection) of nodes extracted from a document.

The NodeList Object

A NodeList object is almost the same as an HTMLCollection object.

Some (older) browsers return a NodeList object instead of an HTMLCollection for methods like getElementsByClassName().

All browsers return a NodeList object for the property childNodes.

Most browsers return a NodeList object for the method querySelectorAll().

The following code selects all <p> nodes in a document.

					 
        
          const myNodeList = document.querySelectorAll("p");
        
      

The elements in the NodeList can be accessed by an index number. The index starts at 0.

To access the second <p> node you can write.

					 
        
          myNodeList[1];
        
      
HTML DOM Node List Length

The length property defines the number of nodes in a node list.

					 
        
          myNodelist.length;
        
      

The length property is useful when you want to loop through the nodes in a node list.

					 
        
          const myNodelist = document.querySelectorAll("p");
          for (let i = 0; i < myNodelist.length; i++) {
            myNodelist[i].style.color = "red";
          }
        
      
The Difference Between an HTMLCollection and a NodeList

A NodeList and an HTMLcollection is very much the same thing.

Both are array-like collections (lists) of nodes (elements) extracted from a document. The nodes can be accessed by index numbers. The index starts at 0.

Both have a length property that returns the number of elements in the list (collection).

An HTMLcollection is a collection of document elements.

A NodeList is a collection of document nodes (element nodes, attribute nodes, and text nodes).

HTMLcollection items can be accessed by their name, id, or index number.

NodeList items can only be accessed by their index number.

An HTMLcollection is always a live collection. Example: If you add a <li> element to a list in the DOM, the list in the HTMLCollection will also change.

A NodeList is most often a static collection. Example: If you add a <li> element to a list in the DOM, the list in NodeList will not change.

The getElementsByClassName() and getElementsByTagName() methods return a live HTMLcollection.

The querySelectorAll() method returns a static NodeList.

The childNodes property returns a live NodeList.

Not an Array!

A NodeList may look like an array, but it is not.

You can loop through a NodeList and refer to its nodes by index.

But, you cannot use Array methods like push(), pop(), or join() on a NodeList.

How you feel about this blog:

Share this blog on:

Report Us

If you find any error in the turtorials, or want to share your suggestion/feedback, feel free to send us email at: info@lynxsia.com

Contact Us
Ads
Logo
Lynxsia IT Solutions

We are concern with various development process like website design & development, E-commerce development, Software development, Application development, SMS & Bulk SMS Provider, PWA Development, and many more..

Kotwali Road, Chhiptehri, Banda, 210001, UP, India

Copyright © 2022, Lynxsia IT Solutions, All rights reserved