码迷,mamicode.com
首页 > 编程语言 > 详细

获取数组中重复的元素

时间:2018-10-20 17:27:59      阅读:155      评论:0      收藏:0      [点我收藏+]

标签:als   style   重复元素   repeat   reac   类型   let   div   ===   

第一种,判断包含基本类型的数组中的重复元素

/**
 * (这里只是判断基本类型的元素)
 * @param  Array
 * @return Array
 */
export const getRepeatElement = (array) => {
  let result = []
  let hash = {}
  array.forEach((item) => {
    if (item) {
      if (!hash[item]) {
        hash[item] = true
      } else {
        result.push(item)
      }
    }
  })

  result = result.filter((item, index, arr) => arr.indexOf(item) === index)

  return result
}

第二种,判断包含对象的数组中的重复元素

/* 去掉对象数组中属性和属性值一样的对象,返回过滤后的数组 */
const getNoRepeatObject = (array) => {
  if (array.length < 2) {
    return array
  }
  let differentObject = []  //放不重复的对象
  let sameObject = [] //放重复对象
  array.forEach(obj => {
    let sameArray = differentObject.filter(tempObj => {
      let isSame = true
      if(Object.keys(tempObj).length === Object.keys(obj).length) {
        for (const key in tempObj) {
          if (!obj.hasOwnProperty(key) || tempObj[key] !== obj[key]) {
            isSame = false
          }
        }
      } else {
        isSame = false
      }
      if (isSame) {
        return tempObj
      }
    })
    if (!sameArray.length) {
      differentObject.push(obj)
    } else {
      sameObject.concat(sameArray)  //将重复的对象放到sameObject数组中,如果需要,也可以返回
    }
  })
  if (differentObject.length === 1) {
    differentObject = []
  }

  return differentObject
}

 

获取数组中重复的元素

标签:als   style   重复元素   repeat   reac   类型   let   div   ===   

原文地址:https://www.cnblogs.com/yyh1/p/9822257.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!