美文网首页
js 数组遍历时删除元素

js 数组遍历时删除元素

作者: 合肥黑 | 来源:发表于2022-04-06 20:45 被阅读0次

参考
js在循环遍历数组中删除指定元素踩坑( foreach.. for.. for..in.. )
JS-数组遍历中删除元素的方法优化

一、删除失效的例子
let arr = [1, 1, 2];
arr.forEach((item, index, arr) => {
    if (item == 1) {
        arr.splice(index, 1);
    }
})
console.log(arr); // [1, 2]

第一次forEach循环,arr是[1, 1, 2],index是0,item是1,if条件成立,使用splice删除了item1,arr变成[1, 2]
第二次forEach循环,arr是[1, 2],index是1,item是2,if条件不成立,使用splice无法删除了第二个重复的1

二、解决方案
1.使用filter()方法筛选符合条件的元素,去除不符合条件的元素
let arr = [1, 1, 2];
arr = arr.filter(item => {
    return item != 1;
});
console.log(arr);
2.删除下标i的时候执行 i--(使下标回退一个位置)

出现问题的原因就是splice删除当前数据时,导致后面的数据前移,最直接的解决办法就是i也跟着前移即可。

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

注意,此时使用For in遍历是不行的

let arr = [1, 1, 2];
for (let i in arr) {
    if (arr[i] == 1) {
        arr.splice(i, 1);
        i--;
    }
}
console.log(arr);// [1, 2]

原因是迭代器的i,每次都重新取值了,i--失效。

3.从后向前遍历,这样就算后面的数据前移,也不影响继续遍历
let arr = [1, 1, 2];
for (let i = arr.length - 1; i >= 0; i--) {
    if (arr[i] == 1) {
        arr.splice(i, 1);
    }
}
console.log(arr);
三、扩展到map
    private testDelMap(): void {
        let m: Map<string, number> = new Map();
        m.set("a", 1);
        m.set("b", 2);
        m.set("c", 3);
        m.set("d", 3);
        m.set("a", 4);
        for (let [k, v] of m) {
            console.log("map k:", k, v);
        }
        for (let [k, v] of m) {
            if (v == 3) {
                m.delete(k);
            }
        }
        for (let [k, v] of m) {
            console.log("new map k:", k, v);
        }
    }

测试结果说明可以安全删除

相关文章

  • js 数组遍历时删除元素

    参考js在循环遍历数组中删除指定元素踩坑( foreach.. for.. for..in.. )[https:/...

  • js笔记

    js数组 删除某个元素 js数组是否含有某个元素 判断value为undefined cookie操作

  • 数组元素删除

    关键词:Array数组删除多个元素、JS、倒序删除 背景? 删除数组中特定条件的元素(可能存在多个)_JS实现。实...

  • js 数组操作合集(主要针对对象数组)

    1,根据对象中元素 查找对象数组中对应的元素 2,删除数组中指定对象的元素 并返回删除后的数组 3,js数组实现权...

  • 基本的数据结构 Array、HashMap 与 List(上)

    Array 1、常用的JS数组内置函数 2、使用数组实现增删改查 在数组中删除元素第一种: 在数组的末尾删除元素所...

  • js 数组删除元素

    没有什么值不值得,生活本该努力 前端QQ群: 981668406在此附上我的QQ: 2489757828 有问题的...

  • JS 数组删除元素

    对JS删除数组中的某个元素进行的一个小封装扩展一个数组删除函数,删除时会改变数组自身的长度,这个方法将直接更改原数...

  • 5.17js二维数组

    5.17日js数组遍历 数组API push给数组添加元素 pop:删除并返回数组的最后一个元素 unshift:...

  • 前端JS:判断list(数组)中的json对象是否重复

    js 删除数组json中重复的元素或者对象 结果:

  • 2021-04-02

    Js数组常用的方法 1,push 后增,数组末尾添加元素,并返回数组的最新长度 2,pop 后删,数组末尾删除元素...

网友评论

      本文标题:js 数组遍历时删除元素

      本文链接:https://www.haomeiwen.com/subject/flpajrtx.html