js数组对象去重_javascript数组去重

(5) 2024-07-13 18:23

Hi,大家好,我是编程小6,很荣幸遇见你,我把这些年在开发过程中遇到的问题或想法写出来,今天说一说
js数组对象去重_javascript数组去重,希望能够帮助你!!!。

1、使用reduce()方法对象数组去重

通过数组的reduce()方法对数组的对象从左到右进行处理,定义一个空对象obj{};

如果数组当前对象的name不在obj{},就将当前对象的name加入到空对象,并将当前对象push到积累变量total数组里;

如果当前对象的name存在obj{},则跳过push操作。

//reduce第一个参数是遍历需要执行的函数,第二个参数是item的初始值 var arr = [{ 
   "id":1,"name":"张三"},{ 
   "id":2,"name":"李四"},{ 
   "id":3,"name":"王五"},{ 
   "id":2,"name":"张三"}]; var obj = { 
   }; arr = arr.reduce(function(item, next) { 
    obj[next.id] ? '' : obj[next.id] = true && item.push(next); return item; }, []); console.log(arr); 

2、利用set去重

可以判断多个属性,这里判断了两个条件,(id 和 name)

var arr2 = [{ 
   "id":1,"name":"张三"},{ 
   "id":2,"name":"李四"},{ 
   "id":3,"name":"王五"},{ 
   "id":2,"name":"张三"},{ 
   'id':4,'name':'李四'}]; function unique(arr){ 
    const res= new Map() return arr.filter((a)=> !res.has(a.id) && res.set(a.id,1) && !res.has(a.name) && res.set(a.name,1)) } //输出结果: unique(arr2) [ { 
    "id": 1, "name": "张三" }, { 
    "id": 2, "name": "李四" }, { 
    "id": 3, "name": "王五" } ] 

今天的分享到此就结束了,感谢您的阅读,如果确实帮到您,您可以动动手指转发给其他人。

上一篇

已是最后文章

下一篇

已是最新文章

发表回复