Loading Please Wait...

Logo Lynxsia IT Solutions

JavaScript HTML DOM Navigation

JS HTML DOM Event Navigation

With the HTML DOM, you can navigate the node tree using node relationships.

DOM Nodes

According to the W3C HTML DOM standard, everything in an HTML document is a node.

  • The entire document is a document node
  • Every HTML element is an element node
  • The text inside HTML elements are text nodes
  • Every HTML attribute is an attribute node (deprecated)
  • All comments are comment nodes

With the HTML DOM, all nodes in the node tree can be accessed by JavaScript.

New nodes can be created, and all nodes can be modified or deleted.

html DOM tree of object
Node Relationships

The nodes in the node tree have a hierarchical relationship to each other.

The terms parent, child, and sibling are used to describe the relationships.

  • In a node tree, the top node is called the root (or root node)
  • Every node has exactly one parent, except the root (which has no parent)
  • A node can have a number of children
  • Siblings (brothers or sisters) are nodes with the same parent
					 
            
              <html>
                <head>
                  <title>DOM Tutorial</title>
                </head>
                <body>
                  <h1>DOM Lesson one</h1>
                  <p>Hello world!</p>
                </body>
              </html>
            
          
DOM node relationship

From the HTML above you can read.

  • <html> is the root node
  • <html> has no parents
  • <html> is the parent of <head> and <body>
  • <head> is the first child of <html>
  • <body> is the last child of <html>
  • <head> has one child: <title>
  • <title> has one child (a text node): "DOM Tutorial"
  • <body> has two children: <h1> and <p>
  • <h1> has one child: "DOM Lesson one"
  • <p> has one child: "Hello world!"
  • <h1> and <p> are siblings
Navigating Between Nodes

You can use the following node properties to navigate between nodes with JavaScript.

  • parentNode
  • childNodes[nodenumber]
  • firstChild
  • lastChild
  • nextSibling
  • previousSibling
Child Nodes and Node Values

A common error in DOM processing is to expect an element node to contain text.

					 
        
          <title id="demo">DOM Tutorial</title>
        
      

The element node <title> (in the example above) does not contain text.

It contains a text node with the value "DOM Tutorial".

The value of the text node can be accessed by the node's innerHTML property.

					 
        
          myTitle = document.getElementById("demo").innerHTML;
        
      

Accessing the innerHTML property is the same as accessing the nodeValue of the first child.

					 
        
          myTitle = document.getElementById("demo").firstChild.nodeValue;
        
      

Accessing the first child can also be done like this.

					 
        
          myTitle = document.getElementById("demo").childNodes[0].nodeValue;
        
      
InnerHTML

In this tutorial we use the innerHTML property to retrieve the content of an HTML element.

However, learning the other methods above is useful for understanding the tree structure and the navigation of the DOM.

DOM Root Nodes

There are two special properties that allow access to the full document.

  • document.body - The body of the document
  • document.documentElement - The full document
					 
        
          <html>
            <body>
              <h1>DOM Lesson one</h1>
              <p>Hello world!</p>
              <p id="demo1"></p>
              <p id="demo2"></p>
              <script>
                document.getElementById("demo1").innerHTML = document.body.innerHTML;
                document.getElementById("demo2").innerHTML = document.documentElement.innerHTML;
              </script>
            </body>
          </html>
        
      
The nodeName Property

The nodeName property specifies the name of a node. nodeName always contains the uppercase tag name of an HTML element.

  • nodeName is read-only
  • nodeName of an element node is the same as the tag name
  • nodeName of an attribute node is the attribute name
  • nodeName of a text node is always #text
  • nodeName of the document node is always #document
					 
        
          <h1 id="demo1">DOM Lesson one</h1>
          <p id="demo2"></p>
          <script>l
            document.getElementById("demo2").innerHTML = document.getElementById("demo1").nodeName;
          </script>
        
      
The nodeValue Property

The nodeValue property specifies the value of a node.

  • nodeValue for element nodes is null
  • nodeValue for text nodes is the text itself
  • nodeValue for attribute nodes is the attribute value
The nodeType Property

The nodeType property is read only. It returns the type of a node.

					 
        
          <h1 id="demo1">DOM Lesson one</h1>
          <p id="demo2"></p>
          <script>l
            document.getElementById("demo2").innerHTML = document.getElementById("demo1").nodeType;
          </script>
        
      

The most important nodeType properties are:

Node Type Example
ELEMENT_NODE 1 <h1 class="heading">Lynxsia</h1>
ATTRIBUTE_NODE 2 class = "heading" (deprecated)
TEXT_NODE 3 Lynxsia
COMMENT_NODE 8 <!-- This is a comment -->
DOCUMENT_NODE 9 The HTML document itself (the parent of <html>)
DOCUMENT_TYPE_NODE 10 <!Doctype html>

Type 2 is deprecated in the HTML DOM (but works). It is not deprecated in the XML DOM.

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