手写数组去重

发布时间:2023年12月18日

说明:以下代码如有考虑不周的bug请评论区留言,我将不断完善或者优化,谢谢

一、看结果

1.执行代码

const arr = [
  { id: 1, name: "数据1" },
  { id: 1, name: "数据2" },
  { id: 2, name: "数据3" },
  { id: 3, name: "数据4" },
  { id: 4, name: "数据5" },
  { id: 3, name: "数据6" },
  { id: 5, name: "数据7" },
  { id: 5, name: "数据7",arr:[1,2],arr1:[1,4] },
  {  name: "数据7",id: 5,arr1:[1,4],arr:[1,2] },
  {  name: "数据7",id: 5,arr:[1,2,3] },
  [1,2,3,[1,'df'], { id: 1, name: "数据1" },],
  [1,2,3,[1,'df'], { id: 2, name: "数据1" },],
  [1,2,3,[1,2]],1,1
]


console.log('last:',deduplicate(arr))

2.结果

二、主要方法

1.deduplicate:去重函数

function deduplicate(arr) {
  if(!Array.isArray(arr)){
    console.log('请传入正确的数组')
    return
  }else{
    if(arr.length<2){
      return arr
    }
    let newArr = arr.reduce((pre,next)=>{
      let isHas = pre.some(item1=>isEquals(item1,next))
      if(!isHas){
        pre.push(next)
      }
      return pre
    },[arr[0]])
    return newArr
  }
}

2.isEquals:判断两个数据是否相等

function getType(data){
  return Object.prototype.toString.call(data).slice(8,-1)
}

function isEquals(data1,data2){
  let type1 = getType(data1)
  let type2 = getType(data2)

  if(type1!==type2){
    return false
  }

  if(type1==='Object'){
    if(Object.keys(data1).length!==Object.keys(data2).length){
      return false
    }else{
      for(let key in data1){
        if(!data2.hasOwnProperty(key)){
          return false
        }else if(!isEquals(data1[key],data2[key])){
          return false
        }
      }
    }
    return true
  }
  if(type1==='Array'){
    if(data1.length!==data2.length){
      return false
    }else{
      for(let i=0;i<data1.length;i++){
        if(!isEquals(data1[i],data2[i])){
          return false
        }
      }
    }
    return true
  }else{
    return data1 === data2
  }
}

文章来源:https://blog.csdn.net/weixin_59017683/article/details/134973609
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。