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()
方法。