为了账号安全,请及时绑定邮箱和手机立即绑定

为什么结果不对

好奇怪,我这样写 var i=0;i<content.childNodes.length-1;i++,运行结果是,第一次点击按钮没反应,第二次点击,后三个删除,第三次点击,倒数第二个删除,第四次点击,才全部删完,为什么会这样

正在回答

1 回答

建议弹出结果一下你就知道为什么是这样的了

 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了,所以只循环了一半,恰好吧空白节点删除了,但是删除空白节点是看不到效果的,所以第一次点击没反应,

之后的原因的点击都一样,只不过没有空白节点了,所以看到的就是你那种效果。。。。。

建议:每次出现问题的时候都试着弹出结果,依次往前找原因。。。。


0 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消

为什么结果不对

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信