最新消息:阿里云双12优惠,史上最低折扣。

数组去重4种有效方法

服务器租用 aliyun 349浏览

域名注册服务商如何更换?注销域名情形有哪些?

申请域名之后是必须需要进行注册,不经注册的域名是无法使用的。关于域名申请的平台有很多,因此根据自己的意愿选择心仪的厂商即可。

面试中或者开发经常会问到数组去重,小睿整理了4种方法。

var arr = [1, 1, ‘1’, ‘1’, ‘true’, ‘true’, true, true, null, null, undefined, undefined, NaN, NaN, {‘a’: 1}, {‘a’: 1}]

1. ES6去重

{}不能去重

 

Array.from(new Set(arr))

// (9) [1, “1”, “true”, true, null, undefined, NaN, {…}, {…}]

2.双重遍历去重

{}、NaN不能去重,可做特殊操作实现

 

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]) {

        debugger;

        arr.splice(j, 1);

        j–;

      }

    }

  }

}

// (10) [1, “1”, “true”, true, null, undefined, NaN, NaN, {…}, {…}]

3. indexOf 或者 includes 去重

需要注意的是 includes 可以去除NaN,而 indexOf 不可以。

 

arr.indexOf(NaN) === -1

 

function unique(arr = []) {

  let newArr = [];

  for(let i = 0; i < arr.length; i++) {

    debugger;

    if(!newArr.includes(arr[i]) || newArr.indexOf(arr[i]) === -1) {

      newArr.push(arr[i]);

    }

  }

  return newArr;

}

// (10) [1, “1”, “true”, true, null, undefined, NaN, NaN, {…}, {…}]

4. filter去重

原理:indexOf只会返回在数组中第一次出现的元素位置

 

arr.filter((item, index, arr) => {

  return arr.indexOf(item) === index;

})

(8) [1, “1”, “true”, true, null, undefined, {…}, {…}]

转载请注明:小猪云服务器租用推荐 » 数组去重4种有效方法