复杂List 去重
1. 函数
1.方式一
function List(arr2) {
let arr = [];
let obj = {};
arr = arr2.reduce(function (prev, cur) {
if (!obj.hasOwnProperty(cur.id)) {
prev.push(cur);
}
obj[cur.id] = true;
return prev;
}, []);
return arr;
}
2.方式二
function unique(arr, key) {
var res = new Map();
return arr.filter(function (a) {
// res.has() 用来表明 map 中是否存在指定元素
// res.set() // 设置key和value
return !res.has(a[key]) && res.set(a[key], 1);
});
}
2.例子
const arr = [
{
id: 1,
name: "s",
},
{
id: 4,
name: "ssss",
},
{
id: 2,
name: "ss",
},
{
id: 3,
name: "sss",
},
{
id: 4,
name: "ssss",
},
{
id: 2,
name: "ss",
},
{
id: 5,
name: "asdadas",
},
];
const res = List(arr);
console.log(res); // 去重后的数据
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?