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.

在这里插入图片描述

2020.11.13 晚23:02 愿你们奔赴在自己的热爱里!

猜你喜欢

转载自blog.csdn.net/weixin_45393094/article/details/109682648