Método XML DOM insertBefore()

Definição e uso

insertBefore() Este método insere um novo nó filho antes do nó filho existente.

Este método retorna o novo nó filho.

Sintaxe

elementNode.insertBefore(new_node,existing_node)
Parâmetros Descrição
new_node Obrigatório. O nó a ser inserido.
existing_node Obrigatório. Nó existente. O novo nó será inserido antes deste nó.

Exemplo

A seguir, o código carregará "books.xml" para xmlDoc, criará um novo nó <book> e o inserirá antes do último elemento <book>:

var xhttp = new XMLHttpRequest();
xhttp.onreadystatechange = function() {
   if (this.readyState == 4 && this.status == 200) {
       myFunction(this);
   }
};
xhttp.open("GET", "books.xml", true);
xhttp.send();
function myFunction(xml) {
    var xmlDoc = xml.responseXML;
    var newNode = xmlDoc.createElement("book");
    var x = xmlDoc.documentElement;
    var y = xmlDoc.getElementsByTagName("book");
    document.getElementById("demo").innerHTML =
    "Elementos de livro antes: " + y.length + "<br>";
    x.insertBefore(newNode, y[3]);
    document.getElementById("demo").innerHTML +=
    "Elementos de livro após: " + y.length;
}

Experimente pessoalmente