利用forEach(以及其他循环方法)删除元素的一个小坑

很久以前被坑了一回,最近一个不注意又傻了吧唧踩了一回,记录一下

let bodys=document.getElementsByClassName("body");

bodys.forEach(b=>{b.remove(b);});

本来是想删除所有的body类,但是最后总是会剩几个

后来发现是因为forEach每次循环index都会+1,例如第一次循环删除bodys[0]后数组剩余元素会往前推,而index依旧+1

bodys=[a,b,c,d]  

index=0,删除bodys[0]=>[b,c,d]  

index=1,删除bodys[1]=>[b,d] 

于是下一次循环删除的元素就是新的bodys[1]了,b就这样被漏掉了~

使用for循环的话就能很快发现问题了,当时偷懒用的forEach没反应过来,被简简单单的小细节困扰了好久😂总之使用循环删除元素的话一定要注意索引变化

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值