• 数组对象去重


    数组对象如下:

        let repeatData = [
          { id: 1, name: 'sun', age: 18 },
          { id: 1, name: 'sun', age: 18 },
          { id: 2, name: 'baozi', age: 20 },
          { id: 1, name: 'sun', age: 18 },
          { id: 3, name: 'lele', age: 3 },
          { id: 2, name: 'baozi', age: 20 }
        ]
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8

    要把id一样的数据删掉,得到如下结果
    在这里插入图片描述

    1.利用Map对象
    Map 对象保存键值对。任何值(对象或者原始值) 都可以作为一个键或一个值。
    Map对象如果有重复的键值,则后面的会覆盖前面的

       // 利用map对象
       let map = new Map()
       repeatData.forEach(item => {
         map.set(item.id, item)
       })
       let newData = [...map.values()]
       console.log(newData, 'newData');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2.双层for循环

       for (let i = 0; i < repeatData.length; i++) {
         for(let j = i + 1; j < repeatData.length; j++) {
           if (repeatData[i].id === repeatData[j].id) {
             repeatData.splice(j, 1)
             j--
           }
         }
       }
       console.log(repeatData, 'repeatData');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    3.利用数组的reduce方法

       let newObj = {}; 
       repeatData = repeatData.reduce((preVal, curVal) => {
         newObj[curVal.id] ? '' : newObj[curVal.id] = preVal.push(curVal);
         return preVal 
       }, [])
       console.log(repeatData, 'repeatData');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    4.利用对象的属性

       let newObj = {}, newArr = []
       repeatData.forEach(item => {
         if (!newObj[item.id]) {
           newObj[item.id] = newArr.push(item)
         }
       })
       console.log(newArr, 'newArr');
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    注意:第二种方法用到的splice方法会改变原数组
    js数组中下面方法会改变原数组:

    方法用法
    push向数组的末尾添加一个或更多元素,并返回新的长度
    unshift向数组的开头添加一个或更多元素,并返回新的长度
    pop删除数组的最后一个元素并返回删除的元素
    shift删除并返回数组的第一个元素
    sort对数组的元素进行排序
    splice从数组中添加或删除元素
    reverse反转数组的元素顺序
  • 相关阅读:
    拳头游戏教程
    【刷题】BFS题目精选
    RESTful 接口设计拓展,接口设计注意事项,注解的简化
    链接脚本(Linker Script)解析
    铝阳极氧化废水除铝
    C++设计模式之Prototype原型模式
    Go语言中的IO
    深度学习visio作图技巧
    获取类对象的三种方法分享
    centos 安装和卸载 webmin
  • 原文地址:https://blog.csdn.net/weixin_46074961/article/details/126408686