ZetCode

JavaScript element.before()

last modified April 2, 2025

In this article, we explore the element.before() method in JavaScript. This method allows developers to insert nodes before a specified element in the DOM tree, providing flexible element manipulation.

Basic Definition

The element.before() method inserts a set of Node or DOMString objects before the element it's called on. These objects are inserted as previous siblings of the element.

This method is part of the modern DOM manipulation API and provides a cleaner alternative to traditional methods like insertBefore. It can accept multiple arguments, inserting them in order before the target element.

Basic element.before()

This example demonstrates how to insert a simple element before another element.

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

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

<script>
    const target = document.getElementById('target');
    const newElement = document.createElement('p');
    newElement.textContent = 'New Element';
    
    target.before(newElement);
</script>

</body>
</html>

In this basic example, we create a new paragraph element and insert it before the target div using element.before(). The new element becomes the previous sibling of the target element.

This demonstrates the fundamental usage of element.before() to insert new content into the DOM. The method modifies the DOM structure directly, without needing to access the parent element explicitly.

Inserting Multiple Elements

This example shows how to insert multiple elements before a target element.

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

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

<script>
    const target = document.getElementById('target');
    const element1 = document.createElement('span');
    element1.textContent = 'First ';
    
    const element2 = document.createElement('span');
    element2.textContent = 'Second ';
    
    target.before(element1, element2, 'Text Node');
</script>

</body>
</html>

Here we create two span elements and a text node, then insert all three before the target element using a single before() call. The elements are inserted in the order they are provided as arguments.

This demonstrates element.before()'s ability to handle multiple insertions at once. The method accepts both element nodes and text strings, which are converted to text nodes automatically.

Inserting Existing Elements

This example demonstrates moving an existing element to a new position.

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

<div id="container">
    <p id="paragraph">Existing Paragraph</p>
    <div id="target">Target Element</div>
</div>

<script>
    const target = document.getElementById('target');
    const paragraph = document.getElementById('paragraph');
    
    target.before(paragraph);
</script>

</body>
</html>

In this example, we move an existing paragraph element to appear before the target div. The before() method automatically removes the element from its current position before inserting it in the new location.

This shows how element.before() can be used to reorganize existing DOM elements. The method handles the removal and reinsertion process automatically, simplifying DOM manipulation.

Combining with Template Literals

This example shows how to use template literals with element.before().

index.html
<!DOCTYPE html>
<html>
<head>
    <title>Template Literals</title>
</head>
<body>

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

<script>
    const target = document.getElementById('target');
    const userName = 'John Doe';
    
    target.before(`<p>Welcome, ${userName}!</p>`);
</script>

</body>
</html>

Here we use a template literal to create HTML content dynamically, which is then inserted before the target element. The string is automatically converted to a DOM node by the browser.

This demonstrates how element.before() can work with dynamically generated content. The method parses HTML strings and inserts the resulting nodes, making it useful for templating scenarios.

Inserting Before with Event Listeners

This example shows how to insert elements with event listeners before a target.

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

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

<script>
    const target = document.getElementById('target');
    const button = document.createElement('button');
    button.textContent = 'Click Me';
    
    button.addEventListener('click', () => {
        alert('Button clicked!');
    });
    
    target.before(button);
</script>

</body>
</html>

In this example, we create a button element, attach a click event listener to it, and then insert it before the target element using before().

This demonstrates that event listeners can be attached to elements before they are inserted into the DOM. The listeners will work normally once the element is inserted into the document.

Source

MDN element.before() Documentation

In this article, we have shown how to use element.before() in JavaScript. This method provides a modern, convenient way to insert content before existing elements in the DOM.

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.