js AppendChild與insertBefore用法詳細(xì)對(duì)比
我們知道appendChild和insertBefore都有插入節(jié)點(diǎn)的功能。但在應(yīng)用上,這兩者之間還是有一些區(qū)別的。
比如我們要在下面這個(gè)div中插入一個(gè)子節(jié)點(diǎn)P時(shí):
<div id="test"><p id="x1">Node</p><p>Node</p></div>
我們可以這樣寫(xiě)(測(cè)試某種情況時(shí)請(qǐng)將另外一種注釋):
<script type="text/javascript">
var oTest = document.getElementById("test");
var newNode = document.createElement("p");
newNode.innerHTML = "This is a test";
//測(cè)試從這里開(kāi)始
//appendChild方法:
oTest.appendChild(newNode);
//insertBefore方法:
oTest.insertBefore(newNode,null);
</script>
通過(guò)以上的代碼,可以測(cè)試到一個(gè)新的節(jié)點(diǎn)被創(chuàng)建到了節(jié)點(diǎn)div下,且該節(jié)點(diǎn)是div最后一個(gè)節(jié)點(diǎn)。(如要查看DOM,IE可以通過(guò)IE Developer Toolbar插件來(lái)查看,F(xiàn)irefox可以使用Firebug)
很明顯,通過(guò)這個(gè)例子,可以知道appendChildhild和insertBefore都可以進(jìn)行插入節(jié)點(diǎn)的操作。
在上面的例子中有這樣一句代碼:oTest.insertBefore(newNode,null) ,這里insertBefore有2個(gè)參數(shù)可以設(shè)置,第一個(gè)是和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>
這個(gè)例子將在x1節(jié)點(diǎn)前面插入一個(gè)新的節(jié)點(diǎn)
又或:
<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>
這個(gè)例子將在x1節(jié)點(diǎn)的下一個(gè)節(jié)點(diǎn)前面插入一個(gè)新的節(jié)點(diǎn)
還可為:
<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>
這個(gè)例子將在第一子節(jié)點(diǎn)前面插入一個(gè)新的節(jié)點(diǎn),也可以通過(guò)改變childNodes[0,1,...]來(lái)在其它位置插入新的節(jié)點(diǎn)
由于可見(jiàn)insertBefore()方法的特性是在已有的子節(jié)點(diǎn)前面插入新的節(jié)點(diǎn),但例一中使用insertBefore()方法也可以在子節(jié)點(diǎn)列表末插入新節(jié)點(diǎn)的。兩種情況結(jié)合起來(lái),發(fā)現(xiàn)insertBefore()方法插入節(jié)點(diǎn),是可以在子節(jié)點(diǎn)列表的任意位置。
從這幾個(gè)例子中得出:
appendChild() 方法在節(jié)點(diǎn)的子節(jié)點(diǎn)列表末添加新的子節(jié)點(diǎn)。
insertBefore() 方法在節(jié)點(diǎn)的子節(jié)點(diǎn)列表任意位置插入新的節(jié)點(diǎn)。
- 初學(xué)js插入節(jié)點(diǎn)appendChild insertBefore使用方法
- javascript實(shí)現(xiàn)的動(dòng)態(tài)添加表單元素input,button等(appendChild)
- JavaScript之a(chǎn)ppendChild、insertBefore和insertAfter使用說(shuō)明
- js中AppendChild與insertBefore的用法詳細(xì)解析
- 走馬燈效果代碼js appendChild實(shí)現(xiàn)的無(wú)縫滾動(dòng)
- js原生appendChild的bug解決心得分享
- javascript appendChild,innerHTML,join性能比較代碼
- javascript使用appendChild追加節(jié)點(diǎn)實(shí)例
- js利用appendChild對(duì)<li>標(biāo)簽進(jìn)行排序的實(shí)現(xiàn)方法
- JS中appendChild追加子節(jié)點(diǎn)無(wú)效的解決方法
相關(guān)文章
JavaScript實(shí)現(xiàn)的瀏覽器下載文件的方法
本文通過(guò)一段簡(jiǎn)單的代碼給大家介紹了js實(shí)現(xiàn)瀏覽器下載文件的方法,需要的的朋友參考下吧2017-08-08JavaScript實(shí)現(xiàn)計(jì)數(shù)器基礎(chǔ)方法
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)計(jì)數(shù)器的基礎(chǔ)方法2017-10-10
,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下js實(shí)現(xiàn)網(wǎng)頁(yè)多級(jí)級(jí)聯(lián)菜單代碼
這篇文章主要介紹了js實(shí)現(xiàn)網(wǎng)頁(yè)多級(jí)級(jí)聯(lián)菜單代碼,涉及javascript基于數(shù)組動(dòng)態(tài)構(gòu)造多級(jí)級(jí)聯(lián)菜單的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2015-08-08js點(diǎn)擊文本框彈出可選擇的checkbox復(fù)選框
這篇文章主要介紹了js點(diǎn)擊文本框彈出可選擇的checkbox復(fù)選框的相關(guān)資料,需要的朋友可以參考下2016-02-02詳談ES6中的迭代器(Iterator)和生成器(Generator)
下面小編就為大家?guī)?lái)一篇詳談ES6中的迭代器(Iterator)和生成器(Generator)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-07-07javascript實(shí)現(xiàn)保留兩位小數(shù)的多種方法
這篇文章主要介紹了javascript實(shí)現(xiàn)保留兩位小數(shù)的多種方法,如果數(shù)字的原本小數(shù)位數(shù)不到兩位,那么缺少的就自動(dòng)補(bǔ)零,感興趣的小伙伴們可以參考一下2015-12-12javascript中undefined與null的區(qū)別
在JavaScript中存在這樣兩種原始類(lèi)型:Null與Undefined。這兩種類(lèi)型常常會(huì)使JavaScript的開(kāi)發(fā)人員產(chǎn)生疑惑,在什么時(shí)候是Null,什么時(shí)候又是Undefined?2015-08-08