js如何一次循环删除数组中的多个元素

思路: 数组遍历删除一个元素很容易,通过splice方法删除对应索引的元素即可,但是遍历删除多个元素就复杂了很多,首先不能按索引从小到大的顺序删除,这样可能会导致索引对应的元素发生变化,误删或找不到该索引对应的元素。那如何做到呢?

示例

下面的示例即实现了一次循环删除多个元素,又实现了将删除的元素合并到新的数组中

let leftData = [1,2,3,4,5]  //原数组
let targetKeys = [3,5]  //要删除的元素
let rightData = [6,7]   //最终需要的数组
let leg = this.leftData.length
for (let i = leg - 1; i >= 0; i--) {
    for (let j = 0; j < targetKeys.length; j++) {
        if (leftData[i]) {
            if (leftData[i] == targetKeys[j]) {
                rightData.push(leftData[i])
                leftData.splice(i, 1)
                continue; //结束当前本轮循环,开始新的一轮循环
            }
        }
    }
}

用途

可以实现穿梭框功能。
穿梭框的实现

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值