本篇文章主要是對js中AppendChild與insertBefore的用法進行了詳細的對比。需要的朋友可以過來參考下,希望對大家有所幫助
我們知道appendChild和insertBefore都有插入節點的功能。但在應用上,這兩者之間還是有一些區別的。 比如我們要在下面這個div中插入一個子節點P時: <div id="test"><p id="x1">Node</p><p>Node</p></div> 我們可以這樣寫(測試某種情況時請將另外一種注釋): 代碼如下: <script type="text/javascript"> var oTest = document.getElementById("test"); var newNode = document.createElement("p"); newNode.innerHTML = "This is a test"; //測試從這裡開始 //appendChild方法: oTest.appendChild(newNode); //insertBefore方法: oTest.insertBefore(newNode,null); </script> 通過以上的代碼,可以測試到一個新的節點被創建到了節點div下,且該節點是div最後一個節點。(如要查看DOM,IE可以通過IE Developer Toolbar插件來查看,Firefox可以使用Firebug) 很明顯,通過這個例子,可以知道appendChildhild和insertBefore都可以進行插入節點的操作。 在上面的例子中有這樣一句代碼:oTest.insertBefore(newNode,null) ,這裡insertBefore有2個參數可以設置,第一個是和appendChild相同的,第二卻是它特有的。它不僅可以為null,還可以為: 代碼如下: <script type="text/javascript"> var oTest = document.getElementById("test"); var refChild = document.getElementById("x1"); var newNode = document.createElement("p"); newNode.innerHTML = "This is a test"; oTest.insertBefore(newNode,refChild); </script> 這個例子將在x1節點前面插入一個新的節點 又或: 代碼如下: <script type="text/javascript"> var oTest = document.getElementById("test"); var refChild = document.getElementById("x1"); var newNode = document.createElement("p"); newNode.innerHTML = "This is a test"; oTest.insertBefore(newNode,refChild.nextSibling); </script> 這個例子將在x1節點的下一個節點前面插入一個新的節點 還可為: 代碼如下: <script type="text/javascript"> var oTest = document.getElementById("test"); var newNode = document.createElement("p"); newNode.innerHTML = "This is a test"; oTest.insertBefore(newNode,oTest.childNodes[0]); </script> 這個例子將在第一子節點前面插入一個新的節點,也可以通過改變childNodes[0,1,...]來在其它位置插入新的節點 由於可見insertBefore()方法的特性是在已有的子節點前面插入新的節點,但例一中使用insertBefore()方法也可以在子節點列表末插入新節點的。兩種情況結合起來,發現insertBefore()方法插入節點,是可以在子節點列表的任意位置。 從這幾個例子中得出: appendChild() 方法在節點的子節點列表末添加新的子節點。 insertBefore() 方法在節點的子節點列表任意位置插入新的節點。