复杂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); // 去重后的数据
posted @ 2022-04-15 16:19  SKa-M  阅读(19)  评论(0编辑  收藏  举报