JavaScript实现删除数组中某个的对象(JavaScript-实践)

简介: 分享JavaScript实现删除数组中某个的对象!案例详解!
hello你好我是辰兮,很高兴你能来阅读,本篇关于前端数组移除对象的相关知识点,也是自己项目中遇到的一点问题,分享获取新知,大家一起进步!

业务场景:表格删除数据后实现刷新表格

场景描述:前端通常情况下获取的是一个数组对象的集合,如果某一个列表涉及到删除操作操作的时候,这时候删除某一个数据后,整个列表要进行刷新
在这里插入图片描述

这里我分享两种处理方法

1.后台实现:再次调用查询的接口,重新查询,列表实现刷新

2.前端实现:前端数组,如List[ ]直接移除删除的对象,绑定监听事件实现表格数据发生变化的时候刷新

常见的前端接受的数组集合举例--包含很多对象

//常见的前端接受的数组集合--包含很多对象
 "list": [
            {
                "id": 16,
                "typeId": 9,
                "weights": 1.00,
                "name": "腾讯内推"      
            },
            {
                "id": 22,
                "typeId": 9,
                "weights": 0.80,
                "name": "百度内推"
            },
            {
                "id": 13,
                "typeId": 8,
                "weights": 0.90,
                "name": "offer许愿池"
            }
        ]

拓展问题:JavaScript根据Id取出数组中指定的对象

从数组中找到id是2020的对象

var obj=arr.find(function (obj) {
            return obj.id === 2020
        })

补充讲解:JavaScript splice() 方法

在这里插入图片描述

定义和用法:splice() 方法向/从数组中添加/删除项目,然后返回被删除的项目。

注释:该方法会改变原始数组。

说明:splice() 方法可删除从 index 处开始的零个或多个元素,并且用参数列表中声明的一个或多个值来替换那些被删除的元素。

arr.splice(i,1); //删除下标为i的元素  前面是索引 后面是数量1代表一个

如果从 arrayObject 中删除了元素,则返回的是含有被删除的元素的数组。


思路一:JavaScript方法,实现数组中找出对象然后移除

其实底层还是调用的splice的方法

核心关键:找到对象索引,然后splice(i,1)

在这里插入图片描述

用如下两个方法就可以实现

先提供一个判断对象是否相等的方法

//判断对象是否相等
function isObjectValueEqual(a, b) {
    if(typeof(a) != "object" && typeof(b) != "object"){
        if(a == b){
            return true;
        }else{
            return false;
        }
    }
    var aProps = Object.getOwnPropertyNames(a);
    var bProps = Object.getOwnPropertyNames(b);

    if (aProps.length != bProps.length) {
        return false;
    }

    for (var i = 0; i < aProps.length; i++) {
        var propName = aProps[i];

        if (a[propName] !== b[propName]) {
            return false;
        }
    }

    return true;
}

再用移除数组中指定对象的方法即可实现移除对象

//从数组中移除对象
function removeObjWithArr(_arr,_obj) {
    var length = _arr.length;
    for(var i = 0; i < length; i++)
    {
        if(isObjectValueEqual(_arr[i],_obj))
        {
            if(i == 0)
            {
                _arr.shift(); //删除并返回数组的第一个元素
                return;
            }
            else if(i == length-1)
            {
                _arr.pop();  //删除并返回数组的最后一个元素
                return;
            }
            else
            {
                _arr.splice(i,1); //删除下标为i的元素
                return;
            }
        }
    }
};

思路二:直接找到索引

从数组中获取指定对象的索引

ps:这里依然要调用上面的判断对象是否相等的方法

//从数组中获取对象的索引
function getIndexInArr(_arr,_obj) {
    var len = _arr.length;
    for(var i = 0; i < len; i++)
    {
        if(isObjectValueEqual(_arr[i],_obj)) {
            return i;
        }
    }
    return -1;
};

删除操作:从索引是i的元素开始删除,删除一个

arr.splice(i,1); //删除下标为i的元素 删除1个

希望我的总结对你有帮助哈哈


The best investment is to invest in yourself.

在这里插入图片描述

愿你们奔赴在自己的热爱里!

目录
相关文章
|
22天前
|
JavaScript 前端开发
JavaScript遍历数组和对象常用方法总结
以上代码展示了数组和对象的多种遍历方法。对于数组,使用了传统的 `for` 循环、`for...in` 和 ES6 的 `for...of` 进行遍历;对于对象,则通过 `for...in`、`Object.keys()`、`Object.values()` 和 `Object.entries()` 来获取键值对。`for...of` 循环适用于遍历具有迭代协议的数据结构,如数组、字符串等,而对象遍历则更多地依赖于 `Object` 方法来获取其属性集合。
JavaScript遍历数组和对象常用方法总结
|
8天前
|
JavaScript
js 解析 byte数组 成字符串
js 解析 byte数组 成字符串
|
25天前
|
数据采集 Web App开发 JavaScript
利用Selenium和XPath抓取JavaScript动态加载内容的实践案例
利用Selenium和XPath抓取JavaScript动态加载内容的实践案例
|
17天前
|
JavaScript 前端开发
JavaScript基础知识-数组的遍历
关于JavaScript数组遍历基础知识的文章。
27 2
JavaScript基础知识-数组的遍历
|
2天前
|
JavaScript 前端开发
js删除数组最后一个元素
js删除数组最后一个元素
|
17天前
|
JavaScript 前端开发
JavaScript基础知识-数组的练习
关于JavaScript基础知识中数组操作的练习,主要介绍了如何从一个包含Person对象的数组中过滤出成年人(年龄达到18岁及以上)并将他们放入一个新的数组中。
25 1
JavaScript基础知识-数组的练习
|
17天前
|
JavaScript 前端开发
JavaScript基础知识-数组的常用方法
关于JavaScript基础知识-数组的常用方法。
15 1
JavaScript基础知识-数组的常用方法
|
17天前
|
JavaScript 前端开发 索引
JavaScript基础知识-数组基于索引访问
关于JavaScript数组基于索引访问的基础知识介绍。
13 1
JavaScript基础知识-数组基于索引访问
|
17天前
|
JavaScript 前端开发
JavaScript基础知识-数组的定义方式
本文介绍了JavaScript中数组的多种定义方式。
11 1
JavaScript基础知识-数组的定义方式
|
17天前
|
JavaScript 前端开发
JavaScript基础知识-枚举对象中的属性
关于JavaScript基础知识中如何枚举对象属性的介绍。
24 1
JavaScript基础知识-枚举对象中的属性