萬盛學電腦網

 萬盛學電腦網 >> 腳本專題 >> javascript >> js AppendChild與insertBefore用法詳細對比

js AppendChild與insertBefore用法詳細對比

 本篇文章主要是對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() 方法在節點的子節點列表任意位置插入新的節點。  
copyright © 萬盛學電腦網 all rights reserved