微信扫一扫看面试题

关注面试题库

js中数组对象去重的方法

最近工作中需要用到数组对象去重的方法,我是怎么想也没想出来,今天稍微研究了一下,总算找到了2种方法。分享一下,希望对大家有帮助!

方法一:

采用对象访问属性的方法,判断属性值是否存在,如果不存在就添加。

方法二:

采用数组中的reduce方法,遍历数组,也是通过对象访问属性的方法

 var arr = [{
        key: '01',
        value: '乐乐'
     }, {
        key: '02',
        value: '博博'
     }, {
      key: '03',
       value: '淘淘'
    },{
       key: '04',
       value: '哈哈'
    },{
       key: '01',
     value: '乐乐'
    }];
 
 
    //  方法1:利用对象访问属性的方法,判断对象中是否存在key
    var result = [];
    var obj = {};
    for(var i =0; i<arr.length; i++){
      if(!obj[arr[i].key]){
         result.push(arr[i]);
          obj[arr[i].key] = true;
      }
    }
   console.log(result); // [{key: "01", value: "乐乐"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]


 
    //  方法2:利用reduce方法遍历数组,reduce第一个参数是遍历需要执行的函数,第二个参数是item的初始值
      var obj = {};
     arr = arr.reduce(function(item, next) {
       obj[next.key] ? '' : obj[next.key] = true && item.push(next);
       return item;
    }, []);
    console.log(arr); // [{key: "01", value: "乐乐"},{key: "02", value: "博博"},{key: "03", value: "淘淘"},{key: "04", value: "哈哈"}]

关注小程序

在这里插入图片描述

posted @ 2022-07-23 10:03  web前端面试小助手  阅读(2287)  评论(0)    收藏  举报