Метод insertBefore() в JavaScript
Метод insertBefore() в JavaScript позволяет вставить новый элемент перед существующим элементом в DOM-дереве.
Синтаксис метода выглядит следующим образом:
parentNode.insertBefore(newNode, referenceNode);
где parentNode — это элемент, перед которым будет вставлен новый элемент newNode, а referenceNode — это элемент, перед которым будет вставлен новый элемент newNode.
Пример использования метода insertBefore():
// Создаем новый элемент
var newElement = document.createElement("p");
var textNode = document.createTextNode("Новый параграф");
newElement.appendChild(textNode);
// Находим элемент, перед которым нужно вставить новый элемент
var referenceElement = document.getElementById("existing-element");
// Находим родительский элемент
var parentElement = referenceElement.parentNode;
// Вставляем новый элемент перед существующим элементом
parentElement.insertBefore(newElement, referenceElement);
В этом примере мы создаем новый элемент p с текстовым содержимым и находим элемент, перед которым нужно вставить новый элемент. Затем мы находим родительский элемент этого элемента и вызываем метод insertBefore(), чтобы вставить новый элемент перед существующим элементом в DOM-дереве.
Метод insertBefore() возвращает вставленный элемент. Если newNode является фрагментом документа, то он вставляется целиком, то есть все его дочерние элементы будут вставлены перед referenceNode. Если newNode уже присутствует в DOM-дереве, он сначала будет удален, а затем снова вставлен перед referenceNode.

