ZetCode

JavaScript element.after()

last modified April 2, 2025

In this article, we explore the element.after() method in JavaScript. This method allows developers to insert nodes or strings after a specified element in the DOM tree.

Basic Definition

The element.after() method inserts a set of Node or string objects in the children list of the element's parent, just after the element itself. It provides a modern way to manipulate DOM structure.

This method is part of the modern DOM manipulation API and is supported in all major browsers. It offers a cleaner alternative to traditional methods like insertBefore or appendChild.

Basic element.after()

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

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Basic element.after()</title>
</head>
<body>

<div id="first">First element</div>

<script>
    const first = document.getElementById('first');
    const second = document.createElement('div');
    second.textContent = 'Second element';
    
    first.after(second);
</script>

</body>
</html>

In this basic example, we have a div element with ID "first". We create a new div element and use after() to insert it after the first element. The result will show both elements in sequence.

This demonstrates the fundamental usage of after() to insert new elements into the DOM. The method modifies the DOM structure directly.

Inserting Multiple Elements

This example shows how to insert multiple elements after a reference element.

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

<div id="reference">Reference element</div>

<script>
    const ref = document.getElementById('reference');
    const elem1 = document.createElement('span');
    const elem2 = document.createElement('p');
    
    elem1.textContent = 'First inserted';
    elem2.textContent = 'Second inserted';
    
    ref.after(elem1, elem2, 'Text node');
</script>

</body>
</html>

Here we insert multiple elements after the reference element. The after() method accepts multiple arguments, which can be elements or text strings.

The elements will be inserted in the order they are provided. Text strings are converted to text nodes automatically by the browser.

Inserting After with Event Listeners

This example demonstrates inserting elements with event listeners.

index.html
<!DOCTYPE html>
<html>
<head>
    <title>With Event Listeners</title>
</head>
<body>

<div id="container">Container</div>
<button id="addBtn">Add Element</button>

<script>
    const container = document.getElementById('container');
    const addBtn = document.getElementById('addBtn');
    
    addBtn.addEventListener('click', () => {
        const newElem = document.createElement('div');
        newElem.textContent = 'New element added at ' + new Date().toLocaleTimeString();
        newElem.style.color = 'blue';
        
        container.after(newElem);
    });
</script>

</body>
</html>

In this example, clicking the button creates a new element with the current time and inserts it after the container div. Each click adds another element below the container.

This shows how after() can be used dynamically in response to user interactions. The inserted elements can have their own styles and properties.

Inserting HTML Strings

This example shows how to insert HTML strings using element.after().

index.html
<!DOCTYPE html>
<html>
<head>
    <title>HTML Strings</title>
</head>
<body>

<div id="target">Target Element</div>

<script>
    const target = document.getElementById('target');
    
    // Using insertAdjacentHTML for HTML strings
    target.insertAdjacentHTML('afterend', '<div class="new">New from HTML string</div>');
    
    // Alternative using after() with createElement
    const newDiv = document.createElement('div');
    newDiv.innerHTML = '<strong>Bold text</strong> created via after()';
    target.after(newDiv);
</script>

</body>
</html>

While after() doesn't directly parse HTML strings, we show two approaches: using insertAdjacentHTML and creating elements first. Both methods achieve similar results.

The example highlights that after() works with element nodes, while HTML strings need either conversion or alternative methods.

Complex DOM Manipulation

This example demonstrates more complex DOM manipulation with after().

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Complex DOM Manipulation</title>
    <style>
        .item { padding: 8px; margin: 4px; border: 1px solid #ccc; }
        .new { background-color: #eef; }
    </style>
</head>
<body>

<div id="list">
    <div class="item" id="item1">Item 1</div>
    <div class="item" id="item3">Item 3</div>
</div>

<script>
    const item1 = document.getElementById('item1');
    const item3 = document.getElementById('item3');
    
    // Create and insert item2
    const item2 = document.createElement('div');
    item2.className = 'item new';
    item2.id = 'item2';
    item2.textContent = 'Item 2 (inserted)';
    item1.after(item2);
    
    // Insert multiple elements after item3
    const item4 = document.createElement('div');
    item4.className = 'item';
    item4.textContent = 'Item 4';
    
    const item5 = document.createElement('div');
    item5.className = 'item new';
    item5.textContent = 'Item 5';
    
    item3.after(item4, item5, 'Additional text node');
</script>

</body>
</html>

This example shows a more complex scenario where we build a list structure by inserting elements at specific positions. We use CSS classes to style newly inserted elements differently.

The example demonstrates how after() can be used to build structured DOM hierarchies with proper styling and organization.

Source

MDN element.after() Documentation

In this article, we have shown how to use element.after() in JavaScript. This method provides a modern, clean way to manipulate DOM structure by inserting elements after reference nodes.

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.