XML DOM insertBefore() 方法

定義和用法

insertBefore() 方法在當前節點的指定子節點之前插入新的子節點。

注意:如果 newchild 已經在樹中,則首先將其刪除。

語法

nodeObject.insertBefore(newchild,existingnode)

參數

參數 描述
newchild 必需。Node 對象。要插入的新的子節點。
existingnode

必需。Node 對象。要在其之前插入新子節點的節點。

如果現有節點為空,則將新子節點插入子節點列表的末尾。

技術細節

DOM 版本: Core Level 1 Node Object。在 DOM Level 3 中修改。
返回值: Node 對象。被插入的節點。

實例

下面的代碼加載 "books.xml",創建一個新的 <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;
}

親自試一試

瀏覽器支持

Chrome Edge Firefox Safari Opera
Chrome Edge Firefox Safari Opera
支持 支持 支持 支持 支持

所有主流瀏覽器都支持 insertBefore() 方法。