首页 > 语言 > JavaScript > 正文

javascript数组去重方法汇总

2024-05-06 16:18:39
字体:
来源:转载
供稿:网友

数组去重复是一个常见的需求,我们暂时考虑同类型的数组去重复。主要是理清思路和考虑下性能。以下方法,网上基本都有,这里只是简单地总结一下。

javascript数组去重方法汇总

 

 
  1. Array.prototype.unique1 = function () { 
  2. var n = []; //一个新的临时数组 
  3. for (var i = 0; i < this.length; i++) //遍历当前数组 
  4. //如果当前数组的第i已经保存进了临时数组,那么跳过, 
  5. //否则把当前项push到临时数组里面 
  6. if (n.indexOf(this[i]) == -1) n.push(this[i]); 
  7. return n; 
  8. }; 
  9. Array.prototype.unique2 = function() 
  10. var n = {},r=[]; //n为hash表,r为临时数组 
  11. for(var i = 0; i < this.length; i++) //遍历当前数组 
  12. if (!n[this[i]]) //如果hash表中没有当前项 
  13. n[this[i]] = true//存入hash表 
  14. r.push(this[i]); //把当前数组的当前项push到临时数组里面 
  15. return r; 
  16. }; 
  17. Array.prototype.unique3 = function() 
  18. var n = [this[0]]; //结果数组 
  19. for(var i = 1; i < this.length; i++) //从第二项开始遍历 
  20. //如果当前数组的第i项在当前数组中第一次出现的位置不是i, 
  21. //那么表示第i项是重复的,忽略掉。否则存入结果数组 
  22. if (this.indexOf(this[i]) == i) n.push(this[i]); 
  23. return n; 
  24. }; 
  25. Array.prototype.unique4 = function() 
  26. this.sort(); 
  27. var re=[this[0]]; 
  28. for(var i = 1; i < this.length; i++) 
  29. ifthis[i] !== re[re.length-1]) 
  30. re.push(this[i]); 
  31. return re; 
  32. }; 
  33. var arr = [1,2,2,2,3,3,4,5]; 
  34. console.log(arr.unique1()); // [1, 2, 3, 4, 5] 
  35. console.log(arr.unique2()); // [1, 2, 3, 4, 5] 
  36. console.log(arr.unique3()); // [1, 2, 3, 4, 5] 
  37. console.log(arr.unique4()); // [1, 2, 3, 4, 5] 

其中第1种和第3种方法都用到了数组的indexOf方法。此方法的目的是寻找存入参数在数组中第一次出现的位置。很显然,js引擎在实现这个方法的时候会遍历数组直到找到目标为止。所以此函数会浪费掉很多时间。 而第2中方法用的是hash表。把已经出现过的通过下标的形式存入一个object内。下标的引用要比用indexOf搜索数组快的多。

第四种方法的思路是先把数组排序,然后比较相邻的两个值。 排序的时候用的JS原生的sort方法,JS引擎内部应该是用的快速排序吧。 最终测试的结果是此方法运行时间平均是第二种方法的三倍左右,不过比第一种和第三种方法快了不少。

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选