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.

在这里插入图片描述

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

目录
相关文章
|
15天前
|
存储 JavaScript 索引
JS中数组的相关方法介绍
JS中数组的相关方法介绍
|
15天前
|
JavaScript Java
JS有趣的灵魂 清空数组
JS有趣的灵魂 清空数组
|
15天前
|
JavaScript
JS 获取对象数据类型的键值对的键与值
JS 获取对象数据类型的键值对的键与值
|
25天前
|
JavaScript 前端开发
Math对象:JavaScript中的数学工具
Math对象:JavaScript中的数学工具
27 1
N..
|
1月前
|
存储 JavaScript 前端开发
JavaScript中的对象
JavaScript中的对象
N..
10 0
|
1月前
|
JavaScript 前端开发 API
常用JavaScript 数组 API大全
常用JavaScript 数组 API大全
32 0
|
18天前
|
JavaScript 算法
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
原生JS完成“一对一、一对多”矩形DIV碰撞检测、碰撞检查,通过计算接触面积(重叠覆盖面积)大小来判断接触对象DOM
|
2天前
|
存储 JavaScript 索引
js开发:请解释什么是ES6的Map和Set,以及它们与普通对象和数组的区别。
ES6引入了Map和Set数据结构。Map的键可以是任意类型且有序,与对象的字符串或符号键不同;Set存储唯一值,无重复。两者皆可迭代,支持for...of循环。Map有get、set、has、delete等方法,Set有add、delete、has方法。示例展示了Map和Set的基本操作。
16 3
|
4天前
|
JavaScript 前端开发 开发者
JavaScript中的错误处理:try-catch语句与错误对象
【4月更文挑战第22天】JavaScript中的错误处理通过try-catch语句和错误对象实现。try块包含可能抛出异常的代码,catch块捕获并处理错误,finally块则无论是否出错都会执行。错误对象提供关于错误的详细信息,如类型、消息和堆栈。常见的错误类型包括RangeError、ReferenceError等。最佳实践包括及时捕获错误、提供有用信息、不忽略错误、利用堆栈信息和避免在finally块中抛错。
|
8天前
|
JavaScript 前端开发 索引
JavaScript 数组中的增、删、改、查
JavaScript 数组中的增、删、改、查