请实现一个 uniq 函数,实现数组去重

10 篇文章 0 订阅
7 篇文章 0 订阅
请实现一个 uniq 函数,实现数组去重

uniq([1, 2, 3, 5, 3, 2]);//[1, 2, 3, 5]

Methods1:利用ES6新增数据类型Set
// 1、
function uniq(arry){
  return [...new Set(arry)]
}
// 2、
function unique10(arr) {
  //Set数据结构,它类似于数组,其成员的值都是唯一的
  return Array.from(new Set(arr)); // 利用Array.from将Set结构转换成数组
}
Methods2:利用数组的indexOf下标属性来查询
function uniq(arry){
    var result = [];
    for(var i = 0; i < arry.length; i++){
        if(result.indexOf(arry[i]) === -1){
            //如果result中没有arry[i],则添加到数组中
            result.push(arry[i])
        }
    }
    return result
}
Methods3:利用数组原型对象上的includes方法
function uniq(arry){
    var result = [];
    for(var i = 0; i < arry.length; i++){
        if(!result.includes(arry[i]) === -1){
            //如果result中没有arry[i],则添加到数组中
            result.push(arry[i])
        }
    }
    return result
}
Methods4:利用reduce
function uniq(arry){
    return arry.reduce((prev,cur)=>prev.includes(cur) ? prev : [..prev,cur],[])
}
Methods5:利用Map
function uniq(arry){
    let map = new Map();
    let result = new Array();
    for(let i = 0; i < arry.length; i++){
        if(map.has(arry[i])){
            map.set(arry[i],true)
        }else{
            map.set(arry[i],false)
            result.push(arry[i])
        }
    }
    return result
}
Methods6:利用数组原型对象上的 filter 和 includes方法组合
function unique(arr) {
  var newArr = []
  newArr = arr.filter(function (item) {
    return newArr.includes(item) ? '' : newArr.push(item)
  })
  return newArr
}
Methods 7: 利用数组原型对象上的 forEach 和 includes方法组合
function unique(arr) {
  let newArr = []
  arr.forEach(item => {
      return newArr.includes(item) ? '' : newArr.push(item)
  })
  return newArr
}
Methods 8:根据数组对象中的某一属性去重
/*
 * @Description: 柱状图是通过echarts象形图绘制而成,导致数据重复,故进行数组重组
 * 根据数组中的对象的seriesName属性进行去重,如果seriesName一样的话,重复只保留一条。根据ES6属性编写函数代码如下:
 */
export function unique(arr) {
  let res = new Map()
  let setArr = arr.filter(item => {
    return !res.has(item.seriesName) && res.set(item.seriesName, 1)
  })
  return setArr
}

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值