JavaScript 存在陷阱 刪除某一區(qū)域所有節(jié)點(diǎn)
更新時(shí)間:2010年05月10日 18:48:33 作者:
實(shí)現(xiàn)功能:刪除某一區(qū)域中所有節(jié)點(diǎn)。
比較簡單的,例如:有一區(qū)域<div id="newbody" ></div>,現(xiàn)要求刪除其中所有節(jié)點(diǎn)。相信很多人會(huì)這樣寫:
var divpanel = document.getElementById("newbody");
var controlinfo= divpanel.childNodes;
for(var index = 0;index < controlinfo.length ;index++)
{
divpanel.removeChild(controlinfo[index]);
}
咋一看,是啊,對啊,這樣很正確啊,一個(gè)一個(gè)遍歷,最后全部刪除。但是,仔細(xì)想想,每當(dāng)刪除一個(gè)節(jié)點(diǎn)后,controlinfo.length就會(huì)變小,這樣下去是不能全部刪除的——存在Bug。那么該如何改進(jìn)呢?已經(jīng)很清楚了,既然從開頭Start不行,那我們就從結(jié)尾Start,完全正確,如下:
var divpanel = document.getElementById("newbody");
var controlinfo= divpanel.childNodes;
for(var index = controlinfo.length - 1;index >= 0 ;index--)
{
divpanel.removeChild(controlinfo[index]);
}
調(diào)試,Very Good!
這種陷阱不只是在JavaScript中才會(huì)碰到,基本上所有的語言,如C#、Java等,我們都會(huì)碰到這樣的問題,有時(shí)會(huì)因?yàn)檫@樣的問題而浪費(fèi)很多的時(shí)間。很早就已經(jīng)知道了這個(gè)問題,不過總是太相信自己的記憶,而沒有好好記錄,現(xiàn)在特記錄下來,警示自己,同時(shí)也與大家分享。
復(fù)制代碼 代碼如下:
var divpanel = document.getElementById("newbody");
var controlinfo= divpanel.childNodes;
for(var index = 0;index < controlinfo.length ;index++)
{
divpanel.removeChild(controlinfo[index]);
}
咋一看,是啊,對啊,這樣很正確啊,一個(gè)一個(gè)遍歷,最后全部刪除。但是,仔細(xì)想想,每當(dāng)刪除一個(gè)節(jié)點(diǎn)后,controlinfo.length就會(huì)變小,這樣下去是不能全部刪除的——存在Bug。那么該如何改進(jìn)呢?已經(jīng)很清楚了,既然從開頭Start不行,那我們就從結(jié)尾Start,完全正確,如下:
復(fù)制代碼 代碼如下:
var divpanel = document.getElementById("newbody");
var controlinfo= divpanel.childNodes;
for(var index = controlinfo.length - 1;index >= 0 ;index--)
{
divpanel.removeChild(controlinfo[index]);
}
調(diào)試,Very Good!
這種陷阱不只是在JavaScript中才會(huì)碰到,基本上所有的語言,如C#、Java等,我們都會(huì)碰到這樣的問題,有時(shí)會(huì)因?yàn)檫@樣的問題而浪費(fèi)很多的時(shí)間。很早就已經(jīng)知道了這個(gè)問題,不過總是太相信自己的記憶,而沒有好好記錄,現(xiàn)在特記錄下來,警示自己,同時(shí)也與大家分享。
相關(guān)文章
微信小程序復(fù)選框?qū)崿F(xiàn)多選一功能過程解析
這篇文章主要介紹了微信小程序復(fù)選框?qū)崿F(xiàn)多選一功能過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02JS 實(shí)現(xiàn)導(dǎo)航欄懸停效果(續(xù)2)
發(fā)現(xiàn)原來的方法還有是有幾個(gè)問題:首先Js代碼冗余,導(dǎo)航條上的Tab是用js實(shí)現(xiàn)跳轉(zhuǎn)而不是超鏈接,還有導(dǎo)航條本身用fixed定位,但沒有被設(shè)置為水平居中,而是在JS中更改left值使其居中2013-09-09深入解析js輪播插件核心代碼的實(shí)現(xiàn)過程
這篇文章主要深度揭密了js輪播插件核心代碼的實(shí)現(xiàn)過程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04JS實(shí)現(xiàn)顯示當(dāng)前日期的實(shí)例代碼
本文通過實(shí)例代碼給大家介紹了js實(shí)現(xiàn)顯示當(dāng)前日期功能,代碼簡單易懂,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2018-07-07使用控制臺(tái)破解百小度一個(gè)月只準(zhǔn)改一次名字
這篇文章主要介紹了使用控制臺(tái)破解百小度一個(gè)月只準(zhǔn)改一次名字的方法和代碼,有需要的小伙伴可以參考下。2015-08-08js 兩數(shù)組去除重復(fù)數(shù)值的實(shí)例
下面小編就為大家分享一篇js 兩數(shù)組去除重復(fù)數(shù)值的實(shí)例,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2017-12-12