我叫张星星
2016-03-11 12:42
好奇怪,我这样写 var i=0;i<content.childNodes.length-1;i++,运行结果是,第一次点击按钮没反应,第二次点击,后三个删除,第三次点击,倒数第二个删除,第四次点击,才全部删完,为什么会这样
建议弹出结果一下你就知道为什么是这样的了
for(var i=0;i<content.childNodes.length-1;i++){
alert('i:'+i+';数组个数: '+content.childNodes.length+';'+content.childNodes[i])//添加测试原因
var x=content.removeChild(content.childNodes[i]);
x=null;
}
我一开始想都没想就这样写了,然后遇到了你的这种结果,
我来解释一下发生这样的原因,
首先,第一次点击没反应的原因是删除的是空白元素,
因为除了ie,其他浏览器换行都算一个空白节点,
第一次循环时,删除的是下标为0的节点,也就是第一个空白节点,然后i加1变成了2,
第二次循环时,删除的是下标为1的节点,其实删除的还是空白节点,因为空白节点之前的h1标签的下标已经从1变成了0,因为第一次循环删除了第一个节点,剩下的节点也就往前移了一位,
然后之后删除的都是空白节点,原理一样
直到i的值达到一个数值,也就是等于length的程度,停止循环,然后由于每次循环length的长度都减1了,所以只循环了一半,恰好吧空白节点删除了,但是删除空白节点是看不到效果的,所以第一次点击没反应,
之后的原因的点击都一样,只不过没有空白节点了,所以看到的就是你那种效果。。。。。
建议:每次出现问题的时候都试着弹出结果,依次往前找原因。。。。
JavaScript进阶篇
468276 学习 · 21892 问题
相似问题