XML DOM insertBefore() 方法
❮ 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;
}
上述代码的输出为:
Book elements before: 4
Book elements after: 5
亲自试一试 »
定义和用法
insertBefore() 方法在当前节点的指定子节点之前插入新的子节点。
注释: 如果newchild已经在树中,则首先将其删除。
浏览器支持
所有主要浏览器都支持 insertBefore() 方法。
语法
nodeObject.insertBefore(newchild,existingnode)
参数
参数 | 类型 | 描述 |
---|---|---|
newchild | Node object | 必须的。要插入的新子节点 |
existingnode | Node object | 必须的。要在之前插入新子节点的节点。 如果existingnode为null,请在子节点列表的末尾插入newchild |
返回值
类型 | 描述 |
---|---|
Node object | 插入的节点 |
技术细节
DOM 版本 | Core Level 1 Node Object. Modified in DOM Level 3 |
---|
❮ Node 节点对象