JavaScript: 迭代删除数组元素

复制代码
const arr = ['a', 'a', 'a', 'd', 'e', 'f']


for (let i = 0; i < arr.length; ++i) {
  console.log(`arr.length = ${arr.length}, i = ${i}`)
  if (arr[i] === 'a') {
    arr.splice(i, 1)
  }
}

console.log(arr)
复制代码

 

i 始终为一个, arr.length不断减少

 

Solution:

复制代码
const arr = ['a', 'a', 'a', 'd', 'e', 'f']


for (let i = 0; i < arr.length; ++i) {
  console.log(`arr.length = ${arr.length}, i = ${i}`)
  if (arr[i] === 'a') {
    arr.splice(i, 1)
    i--
  }
}

console.log(arr)
复制代码

 

for in:

复制代码
const arr = ['a', 'a', 'a', 'd', 'e', 'f']


for (const index in arr) {
  console.log(`arr.length = ${arr.length}, index = ${index}`)
  if (arr[index] === 'a') {
    arr.splice(index, 1)
  }
}

console.log(arr)
复制代码

 

 

for in 每次都重新定义index, 因此const index不会报错, 但是 for 循环使用const会报错, 因此不能使用 index--, 因为 不是同一 index

 

倒叙删除

复制代码
const arr = ['a', 'a', 'a', 'd', 'e', 'f']

for (let i = arr.length - 1; i >= 0; --i) {
  console.log(`arr.length = ${arr.length}, i = ${i}`)
  if (arr[i] === 'a') {
    arr.splice(i, 1)
  }
}

console.log(arr)
复制代码

 

posted @   ascertain  阅读(206)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示