insertBefore()方法是在指定的已有的节点之前插入新的节点,它有两个值,第一个值为要插入的内容,第二个值为指定节点。例如
<body>
<div id="div1"></div>
<ul id="ul2"><li id="li2">1</li><li id="li3">2</li><li id="li4">3</li></ul>
<script>
function change(){
var newItem=document.createElement("li");
var textN=document.createTextNode("ghfgf");
newItem.appendChild(textN);
var list=document.getElementById("ul2");
list.insertBefore(newItem,list.childNodes[2]);
}
</script>
<input type="button" id="btn2" value="插入节点" οnclick="change()">
</body>
在上述例子中,先创建一个新的元素节点,再创建一个文本节点,将文本节点添加到创建的元素节点中,通过getElementById获取ul对象,
将新建节点插入到ul对象的第三个元素之前。
注意:ul列表之所以横着写,中间不留空格是因为insertBefore()方法会考虑空格,如果中间有空格,则ul的第三个元素为
第一个li后面的空格。