Método insertBefore() do XML DOM

Definição e Uso

insertBefore() O método insere um novo subnó antes do subnó especificado do nó atual.

Atenção:Se newchild já estiver na árvore, ele será removido primeiro.

Sintaxe

nodeObject.insertBefore(newchild,existingnode,

)

) Descrição
newchild Obrigatório. Objeto Node. O novo subnó a ser inserido.
existingnode

Obrigatório. Objeto Node. O nó onde o novo subnó será inserido.

Se o nó existente estiver vazio, o novo subnó será inserido no final da lista de subnós.

Detalhes Técnicos

Versão DOM: Objeto Node de Nível Core 1. Modificado no DOM Level 3.
Retorno: Objeto Node. O nó a ser inserido.

Exemplo

O código a seguir carrega "books.xml", cria um novo nó <book> e o insere antes do último nó <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 do livro após: " + y.length;
}

Experimente pessoalmente

Suporte do navegador

Chrome Edge Firefox Safari Opera
Chrome Edge Firefox Safari Opera
Suporte Suporte Suporte Suporte Suporte

Todos os navegadores populares suportam insertBefore() Métodos.