美文网首页
数组去重的方法--总结篇

数组去重的方法--总结篇

作者: 何大必 | 来源:发表于2019-03-11 10:41 被阅读0次

参考:数组去重的六种方法

一、使用for循环

对于数组,没有什么是for循环解决不了的问题。但是bigger不够啊。

function unique(arr) {
  for (let i = 0; i < arr.length; i++) {
    for (let j = i+1; j < arr.length; j++) {
      if (arr[i] == arr[j]) {
        arr.splice(j,1)
        j--
      }
    }
  }
  return arr
}
let arr = [1,1,'true','true', 'a', 'a',true,true,false,false, undefined,undefined, null,null, NaN, NaN,'NaN','NaN', 0, 0,{},{},[],[]];
console.log(unique(arr)) // [ 1, 'true', 'a', false, undefined, NaN, NaN, 'NaN', {}, {} ]

由于使用 ==作比较,会发生类型转换,

1 == true
false== []
undefined == null
false == 0

要解决以上问题我们可以使用Object.is(arr[i], arr[j])的方法替换arr[i]==arr[j]既可以去除NaN还可以防止发生类型转换。也可以使用 === ,but,

+0 === -0 //true
NaN === NaN //false

Object.is(NaN,NaN)//true

拓展 Object.is()

参考链接MDN
Object.is() 判断两个值是否相同。如果下列任何一项成立,则两个值相同:

  • 两个值都是 undefined
  • 两个值都是 null
  • 两个值都是 true 或者都是 false
  • 两个值是由相同个数的字符按照相同的顺序组成的字符串
  • 两个值指向同一个对象
  • 两个值都是数字并且
    • 都是正零 +0
    • 都是负零 -0
    • 都是 NaN
    • 都是除零和 NaN 外的其它同一个数字

二、使用indexOf

使用indexOf(),可以判断一个数组中是否包含某个值,如果存在则返回该元素在数组中的位置,如果不存在则返回-1

function unique(arr) {
    let res = []
    for (let i = 0; i < arr.length; i++) {
        if (res.indexOf(arr[i]) === -1) {
            res.push(arr[i])
        }
   }
  return res
}
console.log(unique(arr)) //[ 1,   'true',   'a',   true,   false,   undefined,   null,   NaN,   NaN,   'NaN',   0,   {},   {}, [], []]

这种方法仍然没有去掉NaN、{}、[]

三、使用includes()

使用includes()方法也可以判断数组是否包含某个特定的元素,如果包含就返回true不包含就返回false。

function unique(arr) {
    let res = []
    for (let i = 0; i < arr.length; i++) {
        if (!res.includes(arr[i])) {
            res.push(arr[i])
        }
    }
    return res
}
console.log(unique(arr)) //[ 1,   'true',   'a',   true,   false,   undefined,   null,   NaN,   NaN,   'NaN',   0,   {},   {}, [], []]

四、使用filter()

filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。并且filter()不会改变数组,也不会对空数组进行检测。filter()方法接收一个回调函数。

array.filter(function(item,index,arr), thisValue)
item 必须。当前元素的值
index 可选。当前元素的索引值
arr 可选。当前元素属于的数组对象

function unique(arr) {
    return arr.filter((item,index, arr) => {
        return arr.indexOf(item) === index
    })
}
console.log(unique(arr)) //[ 1, 'true', 'a', true, false, undefined, null, 'NaN', 0, {}, {}, [], [] ]

五、使用set

function unique(arr) {
  return [...new Set(arr)]
}
console.log(unique(arr)) //[ 1,   'true',   'a',   true,   false,   undefined,   null,   NaN,   'NaN',   0,   {},   {},   [],   [] ]

相关文章

  • 数组去重的方法--总结篇

    参考:数组去重的六种方法 一、使用for循环 对于数组,没有什么是for循环解决不了的问题。但是bigger不够啊...

  • 数组去重方法总结

    简单数组: 1. 基础方法: 思路---新建一新数组,遍历传入数组,值不在新数组就push进该新数组中。 2. 最...

  • 数组去重方法总结

    数组 let arr = [1,2,2,1]进行去重的方法方法1 方法2

  • ES6数组去重

    普通数组去重 方法1 方法2 对象数组去重

  • Array集结号

    实现数组去重的几种方法 数组去重一 数组去重二 利用数组indexof+push实现数组去重 数组去重三 利用对象...

  • js数组去重、对象数组去重

    普通数组去重 一、普通数组去重 方法一:遍历数组法 方法二:排序法 方法三:对象法 对象数组去重 方法一:将对象数...

  • 数组

    数组 数组常用方法 数组去重

  • JavaScript数组去重方法总结

    数组去重,不仅在面试中会被问到,在平时工作中也又遇到过,总结几个常见的去重方法。 一、ES6 Set 不考虑兼容性...

  • 数组去重

    分类 非对象数组去重 对象数组去重 分类一 --- 非对象数组去重 方法一: set(es6常用) 方法二:red...

  • js数组去重方法的总结

    一般大公司面试的时候,都会问一些常见的问题,但是这些问题看着简单,面试官问了怎么解决后,你说了一种,面试官又问还有...

网友评论

      本文标题:数组去重的方法--总结篇

      本文链接:https://www.haomeiwen.com/subject/npcvpqtx.html