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

举报
辰兮 发表于 2022/03/22 22:28:12 2022/03/22
【摘要】 hello你好我是辰兮,很高兴你能来阅读,本篇关于前端数组移除对象的相关知识点,也是自己项目中遇到的一点问题,分享获取新知,大家一起进步! 业务场景:表格删除数据后实现刷新表格 场景描述:前...

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许愿池"
            }
        ]

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

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

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

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

  
 
  • 1
  • 2
  • 3

补充讲解:JavaScript splice() 方法

在这里插入图片描述

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

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

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

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

  
 
  • 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;
}

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26

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

//从数组中移除对象
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;
			}
		}
	}
};

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25

思路二:直接找到索引

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

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;
};

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

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

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

  
 
  • 1

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


The best investment is to invest in yourself.

在这里插入图片描述

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

文章来源: blessing.blog.csdn.net,作者:辰兮要努力,版权归原作者所有,如需转载,请联系作者。

原文链接:blessing.blog.csdn.net/article/details/109682648

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。