数组对象的增删改查

let arr1 = [
{
	age: 12,
	name: 'jake',
	id: '12jake'
},
{
	age: 14,
	name: 'rose',
	id: '14rose'
}
];
let arr2 = [
{
	age: 14,
	name: 'huhu',
	id: '14huhu'
},
{
	age: 12,
	name: 'jake',
	id: '12jake'
}
];

增项

push+includes

  • 两个数组对象合并为一个数组对象
let arrStr1 = JSON.stringify(arr1);
arr2.map((item) => {
	let itemStr = JSON.stringify(item);
	if(!arrStr1.includes(itemStr)) {
		arr1.push(item)
	}
});
console.log(arr1);

Map

let aryMap = arr2.map(item => {
	item = [JSON.stringify(item), item];
	return item;
});
aryMap = new Map(aryMap);
arr1.map(v => {
	aryMap.set(JSON.stringify(v),v);
});
let newAry = [...aryMap.values()];
console.log(newAry);
//[
//  { age: 14, name: 'huhu', id: '14huhu' },
//  { age: 12, name: 'jake', id: '12jake' },
//  { age: 14, name: 'rose', id: '14rose' }
//]

数组对象去重

let arr3 = [...arr1, ...arr2];

Set

  • new Set 对引用类型的对象无效,所以需要转化类型进行去重
let newArr = [...new Set(arr3.map(item => JSON.stringify(item)))].map(item => JSON.parse(item));
console.log(newArr);
//[
//  { age: 12, name: 'jake', id: '12jake' },
//  { age: 14, name: 'rose', id: '14rose' },
//  { age: 14, name: 'huhu', id: '14huhu' }
//]

Map

let aryObj = arr3.map(item => {
	item = [JSON.stringify(item), item];
	return item;
});
aryObj = new Map(aryObj);
let newArr = [...aryObj.values()];
console.log(newArr);

filter

  • 过滤查找,取一项,循环所有剩余其他项;排除自己,也排除已经比较过的,比较当前项和其他剩余项的属性值是否相同,相同则重复,返回false进行排除。
let newArr = arr3.filter((v,k) => !arr3.some((item, key) => {
	if(k != key && k > key) {
		return Object.keys(item).length === Object.keys(v).length && Object.keys(item).every(index => v[index] === item[index]) // 长度相同再比较内部的属性值
	} else {
		return false
	}
}));
console.log(newArr);

提取数组中某项重组成新数组

let newObjAry= arr2.map(item => {
	return {code: item.id, newName: item.name}
});
console.log(newObjAry);
let arr = [];
arr2.map(item => {
	let obj = {};
	obj['code'] = item.id;
	obj['newName'] = item.name;
	arr.push(obj)
});
console.log(arr);
let arr = arr2.map(item => {
	return Object.assign({}, {code: item.id, newName: item.name})
});
console.log(arr);
//[
//  { code: '14huhu', newName: 'huhu' },
//  { code: '12jake', newName: 'jake' }
//]
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值