zoukankan      html  css  js  c++  java
  • 为Array对象添加一个去除重复项的方法

    输入例子

    
    [false, true, undefined, null, NaN, 0, 1, {}, {}, 'a', 'a',  NaN].uniq()
    
    

    输出例子

    
    [false, true, undefined, null, NaN, 0, 1, {}, {}, 'a']
    
    

    分析

    
    Array.prototype.uniq = function () {
      var arr = [];
      var flag = true;
      this.forEach(function(item) {
        // 排除 NaN (重要!!!)
        if (item != item) {
          flag && arr.indexOf(item) === -1 ? arr.push(item) : '';
          flag = false;
        } else {
          arr.indexOf(item) === -1 ? arr.push(item) : ''
        }
      });
      return arr;
    }
    
    

    验证

    我们只需要在数组上直接调用 uniq 方法就可以了,如:
    
    [false, true, undefined, null, NaN, 0, 1, {}, {}, 'a', 'a',  NaN].uniq()
    
    

    结果为:

    
    [false, true, undefined, null, NaN, 0, 1, {}, {}, 'a']
    
    

    进阶

    ES6的实现

    ES6新增了 Set 对象,也就是我们所说的“集合”,它类似于数组,但是成员 的值都是唯一的,没有重复的值。所以可以方便去重。 Set本身是一个构造函数,用来生成Set数据结构。(详看Set和Map数据结构) 如果用ES6为 Array 对象添加一个去除重复项的方法,则可以如下实现:
    
    Array.prototype.uniq = function() {
      return Array.from(new Set(this));
    }
    
    

    代码中用 Array.from 把 Set 结构转换成数组,当然,你也可以用其他方法, 这里不深究。这里去重关键代码只需要一行,是不是非常简单???
    如果你要优雅一点,可以使用 ES6 的扩展运算符。如下:

    
    Array.prototype.uniq = function() {
      return [...new Set(this)];
    }
    
    

    原文链接:https://microzz.com/2017/04/01/array-uniq/

  • 相关阅读:
    第六周作业
    第六周上机练习
    第十二周作业
    第十二周上机练习
    第十一周作业
    第十一周上机练习
    第十周上机练习
    第九周上机练习
    第八周作业
    第八周上机练习
  • 原文地址:https://www.cnblogs.com/lovellll/p/10109563.html
Copyright © 2011-2022 走看看