Nodejs Array Unique unique(k)

Here you can find the source of unique(k)

Method Source Code

Array.prototype.unique = function(k) {
    var self = this;
    var result = [];
    var sublen = 0;
    for (var i = 0, l = self.length; i < l; i++) {
        var v = self[i];
        if (!k) {
            if (result.indexOf(v) === -1) {
                result.push(v);/*from w  ww.  j a va2s  .co m*/
            }
            continue;
        }
        if (sublen === 0) {
            result.push(v);
            sublen++;
            continue;
        }
        var is = true;
        for (var j = 0; j < sublen; j++) {
            if (result[j][k] === v[k]) {
                is = false;
                break;
            }
        }
        if (is) {
            result.push(v);
            sublen++;
        }
    }
    return result;
};

Related

  1. unique(b)
    Array.prototype.unique = function(b) {
        var a = [], i, l = this.length;
        for (i = 0; i < l; i++) {
            if (a.indexOf(this[i], 0, b) < 0) {
                a.push(this[i]);
        return a;
    };
    ...
    
  2. unique(b)
    Array.prototype.unique = function(b) {
      var a = [], i, l = this.length;
      for (i = 0; i < l; i++) {
        if (a.indexOf(this[i], 0, b) < 0) {
          a.push(this[i]);
      return a;
    };
    ...
    
  3. unique(callback)
    Array.prototype.unique = function(callback) {
      var o = {}, i, l = this.length, r = [];
      for (i=0; i<l; i+=1) {
        var val = callback(this[i]);
        o[val] = this[i];
      for (i in o) {
        r.push(o[i]);
      return r;
    };
    
  4. unique(data)
    Array.prototype.unique = function(data) {
      data.sort();
      var re = [ data[0] ];
      var length = data.length;
      for (var i = 1; i < length; i++) {
        if (data[i] !== re[re.length - 1]) {
          re.push(data[i]);
      return re;
    };
    
  5. unique(fun, map)
    (
      Array.prototype.unique = function (fun, map) {
        fun = fun || (function(c) { return c; });
        var arrayUnique = [this[0]], 
        arrayUniqueAtt = [fun(this[0])];
        this.forEach(function(el){
          if (arrayUniqueAtt.indexOf(fun(el)) === -1) {
            arrayUniqueAtt.push(fun(el));
            arrayUnique.push(el);
    ...
    
  6. unique(mutate)
    Array.prototype.unique = function (mutate) {
      var unique = this.reduce(function (accum, current) {
        if (accum.indexOf(current) < 0) {
          accum.push(current);
        return accum;
      }, []);
      if (mutate) {
        this.length = 0;
    ...
    
  7. unique(str)
    Array.prototype.unique = function(str){
      const seen = new Map()
      return this.filter((a) => {
        return !seen.has(a['name']) && seen.set(a['name'], 1)
      })
    
  8. unique1()
    Array.prototype.unique1 = function(){
      var res = [this[0]];
      for(var i = 1; i < this.length; i++){
        var repeat = false;
        for(var j = 0; j < res.length; j++){
          if(this[i] == res[j]){
            repeat = true;
            break;
        if(!repeat){
          res.push(this[i]);
      return res;
    var arr = [1, 'a', 'a', 'b', 'd', 'e', 'e', 1, 0]
    console.log(arr.unique1());
    
  9. unique1()
    Array.prototype.unique1 = function () {
      var a = [],
        o = {},
        n = this.length;
        for (var i=0; i<n; ++i) {
          o[this[i]] = this[i];
        for (var i in o) {
          a.push(o[i]);
    ...