🎁 Exclusive offer: Get EXTRA Bits and Celebrate Bybit's 6th Birthday With $2.2M Prize Pool. Act Now!

Code has been added to clipboard!

Discover JavaScript HTML DOM Navigation With Real Examples

Reading time 5 min
Published Aug 8, 2017
Updated Oct 2, 2019

One of the many features of JavaScript is knowing how to work with nodes. Once you access the Document Object Model (DOM) nodes of specific elements, you can manage their properties, orientation, and appearance. In this tutorial, you will learn all about JavaScript HTML Document Object Model Navigation.

DOM nodes help you analyze relations between elements. Because of the element nesting, a node tree is created to provide better visualization. The structure and relationships between nodes will be explained as well. You will find out what a root, parent, child, and a sibling is in a node tree.

JavaScript HTML DOM Navigation: Main Tips

  • The HTML DOM allows you to navigate the node tree by making use of the node relationships.
  • By learning to navigate the document object model (DOM), you can make use of every object in the HTML that your JavaScript will be applied to.

What are Nodes and How are They Connected

The HTML Document Object Model standard says that everything in HTML documents is a node:

  • The document itself is a document node.
  • Each element is an element node.
  • All of the text inside the elements are text nodes.
  • Each attribute assigned to an element is an attribute node.
  • Each comment is a comment node.

Using the HTML document object model, each of these nodes is accessible to JavaScript. You can create new nodes, and each node can be deleted or modified.

The nodes are connected by hierarchical relationships in the DOM tree. The terms parent, child, and sibling are used to describe this relationship:

  • Root is the top node of the tree.
  • Parent is an element that contains other elements. Every element has one, except for the root.
  • Child is below, or contained by, the parent. A parent may have any number of child nodes.
  • Siblings are nodes under the same parent.

Let's illustrate this with an example:

Example
<html>
<head>
	<title>Amazingly Creative Title</title>
</head>

<body>
	<h2>Wonderful Heading</h2>
	<div>The text!</div>
</body>
</html>

In an example of an HTML script above, you can see that:

  • <html> is the root node, has no parent and is the parent of <head> and <body>.
  • <head> and <body> are children of <html>.
  • <title> is a child of <head> and has a single child, which is a text node Amazingly Creative Title.
  • <body> has two children: <h2> and <div>.
  • <h2> has a single child text node: Wonderful Heading.
  • <div> has a single child text node: The text!.
  • <h2> and <div> are siblings.

The following node properties allow you to navigate the DOM tree using JavaScript:

  • childNodes[nodeNumber]
  • parentNode
  • lastChild
  • firstChild
  • previousSibling
  • nextSibling

Expecting an element node to contain text is a frequent error when working with the document object model.

For example: in the case of <title>Amazingly Creative Title</title>, the element node <title> itself contains no text. However, it does contain a text node Amazingly Creative Title.

This can be accessed by using the nodeValue property, or innerHTML.

DataCamp
Pros
  • Easy to use with a learn-by-doing approach
  • Offers quality content
  • Gamified in-browser coding experience
  • The price matches the quality
  • Suitable for learners ranging from beginner to advanced
Main Features
  • Free certificates of completion
  • Focused on data science skills
  • Flexible learning timetable
Udacity
Pros
  • Simplistic design (no unnecessary information)
  • High-quality courses (even the free ones)
  • Variety of features
Main Features
  • Nanodegree programs
  • Suitable for enterprises
  • Paid Certificates of completion
edX
Pros
  • A wide range of learning programs
  • University-level courses
  • Easy to navigate
  • Verified certificates
  • Free learning track available
Main Features
  • University-level courses
  • Suitable for enterprises
  • Verified certificates of completion

Child Nodes and Node Values

While the innerHTML property is handy for changing the content of an element, childNodes and nodeValue properties can be used to get the element's content.

The code in the example below gets the value of <h2> element and copies it into a <div> element:

Example
<html>
<body>
  <div id="el1">Amazingly Creative Heading</div>  
  <div id="el2">Look this text DOM!</div> 

<script>
  document.getElementById("el2").innerHTML = document.getElementById("el1").childNodes[0].nodeValue;
</script>
</body>
</html>

In the example above, getElementById is a method, meanwhile childNodes and nodeValue are properties.

For the purposes of this tutorial, we are going to use the innerHTML property. This does not mean the above method is somehow less useful for learning and understanding the DOM's underlying structure!

Keep in mind that using firstChild has a similar effect as childNodes[0].

Example
<html>
<body>
    <h2 id="el1">Amazingly Creative Title</h2>
    <div id="el2">the Text!</div>
<script>
    document.getElementById("el2").innerHTML = document.getElementById("el1").firstChild.nodeValue;
</script>
</body>
</html>

DOM Root Nodes

There are two JavaScript get body element properties that allow you to access the document node itself:

  • document.body is used for getting the document's body.
  • document.documentElement used to get the whole document.

Look at the examples below to see both of them used in code:

Example
<html> 
<body>
<script> 
    alert(document.body.innerHTML); 
</script> 
<p>Amazingly Creative Title</p>  
<div>  
    <p>Hail the DOM!</p>  
    <p>Witness the power of the <strong>document.body</strong> property.</p>  
</div>    
</body>
</html>

Example
<html>  
<body>
<script>
    alert(document.documentElement.innerHTML); 
</script> 
    <p>Check this out!</p>
    <div>
        <p>Hail the DOM!</p>
        <p>Witness the power of the <strong>document.documentElement</strong> property!</p>
    </div>
</body>
</html>

Properties You Should Know

The nodeName property is used to specify the node's name and is always read-only. It can return these values:

  • Tag name
  • Attribute name
  • #text (in case of a text node).
  • #document (in case of a document node).
  • #comment (in case of a comment node).

Note: nodeName will always contain the HTML element name in uppercase.

Now, the nodeValue property is used to specify the value of a node. It has three possible return values:

  • NULL (in case of a document or element node)
  • Content (in case of a text or comment node)
  • Attribute value (in case of an attribute node)

The nodeType property is used to return the type of node. Review the table below to see the most important types of nodes:

Element type nodeType
Element 1
Attribute 2
Text 3
Comment 8
Document 9

JavaScript HTML DOM Navigation: Summary

  • You can navigate the DOM with JavaScript through node relationships.
  • Node relationships are defined as root, parent, child, and sibling.
  • There are various node properties you can use to access nodes.