XML DOM insertBefore() メソッド

定義と用法

insertBefore() このメソッドは既存の子ノードの前に新しい子ノードを挿入します。

このメソッドは新しい子ノードを返します。

構文

elementNode.insertBefore(new_node,existing_node)
パラメータ 説明
new_node 必須。挿入するノード。
existing_node 必須。既存のノード。新しいノードはこのノードの前に挿入されます。

以下のコードは "books.xml" を xmlDoc にロードし、新しい <book> ノードを作成し、最後の <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 =
    "Book elements before: " + y.length + "<br>";
    x.insertBefore(newNode, y[3]);
    document.getElementById("demo").innerHTML +=
    "Book elements after: " + y.length;
}

実際に試してみる