ZetCode

JavaScript insertBefore

last modified April 2, 2025

In this article, we explore the element.insertBefore method in JavaScript. This method is essential for DOM manipulation, allowing developers to insert elements at specific positions within the DOM tree.

Basic Definition

The insertBefore method inserts a node before a reference node as a child of a specified parent node. This is a powerful method for precise DOM manipulation and element positioning.

The syntax is: parentNode.insertBefore(newNode, referenceNode). If the reference node is null, the new node is inserted at the end of the parent's child list.

Basic insertBefore Example

This example demonstrates how to insert a new element before an existing one.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Basic insertBefore</title>
</head>
<body>

<ul id="list">
    <li>First item</li>
    <li id="second">Second item</li>
    <li>Third item</li>
</ul>

<script>
    const list = document.getElementById('list');
    const secondItem = document.getElementById('second');
    const newItem = document.createElement('li');
    
    newItem.textContent = 'New item';
    list.insertBefore(newItem, secondItem);
</script>

</body>
</html>

In this example, we create a new list item and insert it before the second item in the list. We first get references to the parent list and the reference node.

The insertBefore method places our new element exactly where we want it in the DOM hierarchy. This demonstrates basic DOM manipulation with precise positioning.

Inserting Before First Child

This example shows how to insert an element at the beginning of a parent.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Insert Before First Child</title>
</head>
<body>

<div id="container">
    <p>Existing paragraph</p>
</div>

<script>
    const container = document.getElementById('container');
    const newHeading = document.createElement('h2');
    
    newHeading.textContent = 'New Heading';
    container.insertBefore(newHeading, container.firstChild);
</script>

</body>
</html>

Here we insert a new heading before the first child of the container div. We use the firstChild property to reference the existing paragraph.

This technique is useful when you need to prepend content to an element while preserving its existing children. The firstChild property provides easy access to the insertion point.

Inserting at the End

This example demonstrates inserting when the reference node is null.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Insert at End</title>
</head>
<body>

<div id="gallery">
    <img src="image1.jpg" alt="Image 1">
    <img src="image2.jpg" alt="Image 2">
</div>

<script>
    const gallery = document.getElementById('gallery');
    const newImage = document.createElement('img');
    
    newImage.src = 'image3.jpg';
    newImage.alt = 'Image 3';
    gallery.insertBefore(newImage, null);
</script>

</body>
</html>

When the reference node is null, insertBefore behaves like appendChild, adding the new node at the end of the parent's child list.

This approach is useful when you want to ensure consistent behavior whether you're inserting before a specific node or at the end of the list.

Moving Existing Elements

This example shows how to move an existing element to a new position.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Moving Elements</title>
</head>
<body>

<div id="list1">
    <p id="item1">Item 1</p>
    <p id="item2">Item 2</p>
</div>

<div id="list2">
    <p id="item3">Item 3</p>
</div>

<button onclick="moveItem()">Move Item</button>

<script>
    function moveItem() {
        const list1 = document.getElementById('list1');
        const list2 = document.getElementById('list2');
        const item1 = document.getElementById('item1');
        
        list2.insertBefore(item1, list2.firstChild);
    }
</script>

</body>
</html>

Here we move "Item 1" from "list1" to the beginning of "list2" when the button is clicked. The element is automatically removed from its original position.

This demonstrates that insertBefore can move existing nodes without needing to clone them. The DOM automatically handles the relocation.

Dynamic List Reordering

This example shows how to reorder list items using insertBefore.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>List Reordering</title>
</head>
<body>

<ul id="todo-list">
    <li>Buy groceries</li>
    <li id="important">Finish project</li>
    <li>Call mom</li>
</ul>

<button onclick="prioritize()">Prioritize Important</button>

<script>
    function prioritize() {
        const list = document.getElementById('todo-list');
        const important = document.getElementById('important');
        
        list.insertBefore(important, list.firstChild);
    }
</script>

</body>
</html>

This example moves the important task to the top of the todo list when the button is clicked. We get references to both the list and the important item.

The insertBefore method is perfect for dynamic list reordering scenarios. It provides precise control over element positioning in the DOM.

Source

MDN insertBefore Documentation

In this article, we have shown how to use element.insertBefore in JavaScript. This method is fundamental for precise DOM manipulation and element positioning in web development.

Author

My name is Jan Bodnar, and I am a passionate programmer with extensive programming experience. I have been writing programming articles since 2007. To date, I have authored over 1,400 articles and 8 e-books. I possess more than ten years of experience in teaching programming.

List all JS DOM tutorials.