Метод insertBefore в JavaScript
Метод insertBefore
позволяет вставить элемент перед другим элементом. Чаще всего используется после создания элемента с помощью createElement
. Метод применяется к родителю того элемента, перед которым произойдет вставка.
Синтаксис
родитель.insertBefore(элемент, перед кем вставить)
Пример
Создадим абзац и поместим его перед вторым абзацем:
<div id="parent">
<p>elem 1</p>
<p id="before">elem 2</p>
<p>elem 3</p>
</div>
let parent = document.querySelector('#parent');
let before = document.querySelector('#before');
let p = document.createElement('p');
p.innerHTML = '!';
parent.insertBefore(p, before);
// <div id="parent">
// <p>elem 1</p>
// <p>!</p>
// <p>elem 2</p>
// <p>elem 3</p>
// </div>
Пример
Добавим абзац в начало элемента #parent
. Для этого вставим наш абзац перед первым потомком #parent
. Этого потомка можно найти с помощью firstElementChild
:
<div id="parent">
<p>elem 1</p>
<p>elem 2</p>
</div>
let parent = document.querySelector('#parent');
let p = document.createElement('p');
p.innerHTML = '!';
parent.insertBefore(p, parent.firstElementChild);
// <div id="parent">
// <p>!</p>
// <p>elem 1</p>
// <p>elem 2</p>
// </div>
Пример
При передаче вторым параметром null
метод insertBefore
срабатывает как appendChild
. В то же время, если в элементе нет дочерних элементов, firstElementChild
возвращает null
. Следовательно, добавлять в начало элемента можно даже тогда, когда в нем нет дочерних элементов:
<div id="parent"></div>
let parent = document.querySelector('#parent');
let p = document.createElement('p');
p.innerHTML = '!';
parent.insertBefore(p, parent.firstChild);
// <div id="parent">
// <p>!</p>
// </div>