手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JavaScript 存在陷阱 删除某一区域所有节点
JavaScript 存在陷阱 删除某一区域所有节点
摘要:比较简单的,例如:有一区域,现要求删除其中所有节点。相信很多人会这样写:复制代码代码如下:vardivpanel=document.getE...

比较简单的,例如:有一区域<div id="newbody" ></div>,现要求删除其中所有节点。相信很多人会这样写:

复制代码 代码如下:

var divpanel = document.getElementById("newbody");

var controlinfo= divpanel.childNodes;

for(var index = 0;index < controlinfo.length ;index++)

{

divpanel.removeChild(controlinfo[index]);

}

咋一看,是啊,对啊,这样很正确啊,一个一个遍历,最后全部删除。但是,仔细想想,每当删除一个节点后,controlinfo.length就会变小,这样下去是不能全部删除的——存在Bug。那么该如何改进呢?已经很清楚了,既然从开头Start不行,那我们就从结尾Start,完全正确,如下:

复制代码 代码如下:

var divpanel = document.getElementById("newbody");

var controlinfo= divpanel.childNodes;

for(var index = controlinfo.length - 1;index >= 0 ;index--)

{

divpanel.removeChild(controlinfo[index]);

}

调试,Very Good!

这种陷阱不只是在JavaScript中才会碰到,基本上所有的语言,如C#、Java等,我们都会碰到这样的问题,有时会因为这样的问题而浪费很多的时间。很早就已经知道了这个问题,不过总是太相信自己的记忆,而没有好好记录,现在特记录下来,警示自己,同时也与大家分享。

【JavaScript 存在陷阱 删除某一区域所有节点】相关文章:

JavaScript实际应用:innerHTMl和确认提示的使用

JavaScript实现添加、查找、删除元素

详解JavaScript中setSeconds()方法的使用

基于JavaScript实现动态添加删除表格的行

Javascript生成全局唯一标识符(GUID,UUID)的方法

JavaScript检测字符串中是否含有html标签实现方法

Javascript实现图片轮播效果(二)图片序列节点的控制实现

JavaScript编程学习技巧汇总

JavaScript检查数字是否为整数或浮点数的方法

javascript实现模拟时钟的方法

精品推荐
分类导航