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.
愿你们奔赴在自己的热爱里!