Site icon DW Faisalabad

JavaScript HTML DOM 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:

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.


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.

<html>

<head><title>DOM Tutorial</title>
</head>

<body>
<h1>DOM Lesson one</h1>
<p>Hello world!</p>
</body>

</html>

From the HTML above you can read:

and:

Navigating Between Nodes

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


Child Nodes and Node Values

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

Example:

<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:

var myTitle = document.getElementById(“demo”).innerHTML;

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

var myTitle = document.getElementById(“demo”).firstChild.nodeValue;

Accessing the first child can also be done like this:

var myTitle = document.getElementById(“demo”).childNodes[0].nodeValue;

All the (3) following examples retrieves the text of an <h1> element and copies it into a <p> element:

Example

<html>
<body><h1 id=”id01″>My First Page</h1>
<p id=”id02″></p><script>
document.getElementById(“id02”).innerHTML = document.getElementById(“id01”).innerHTML;
</script></body>
</html>

Try it Yourself »

Example

<html>
<body><h1 id=”id01″>My First Page</h1>
<p id=”id02″></p><script>
document.getElementById(“id02”).innerHTML = document.getElementById(“id01”).firstChild.nodeValue;
</script></body>
</html>

Test »

Example

<html>
<body><h1 id=”id01″>My First Page</h1>
<p id=”id02″>Hello!</p><script>
document.getElementById(“id02”).innerHTML = document.getElementById(“id01”).childNodes[0].nodeValue;
</script></body>
</html>

Test »


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:

Example

<html>
<body><p>Hello World!</p>
<div>
<p>The DOM is very useful!</p>
<p>This example demonstrates the <b>document.body</b> property.</p>
</div><script>
alert(document.body.innerHTML);
</script></body>
</html>

Try it Yourself »

Example

<html>
<body><p>Hello World!</p>
<div>
<p>The DOM is very useful!</p>
<p>This example demonstrates the <b>document.documentElement</b> property.</p>
</div><script>
alert(document.documentElement.innerHTML);
</script></body>
</html>

Try it Yourself »


The nodeName Property

The nodeName property specifies the name of a node.

Example

<h1 id=”id01″>My First Page</h1>
<p id=”id02″></p><script>
document.getElementById(“id02”).innerHTML = document.getElementById(“id01”).nodeName;
</script>

Test »

Note: nodeName always contains the uppercase tag name of an HTML element.


The nodeValue Property

The nodeValue property specifies the value of a node.


The nodeType Property

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

Example

<h1 id=”id01″>My First Page</h1>
<p id=”id02″></p><script>
document.getElementById(“id02”).innerHTML = document.getElementById(“id01”).nodeType;
</script>

Test »

The most important nodeType properties are:

Node Type Example
ELEMENT_NODE 1 <h1 class=”heading”>W3Schools</h1>
ATTRIBUTE_NODE 2  class = “heading” (deprecated)
TEXT_NODE 3 W3Schools
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.

Exit mobile version