JavaScript数组去重方法

时间:2021-09-01 19:04:17

在Js中如何快速的去除数组中的重复值通常会被用来当做笔试题,这里介绍两个方法,从国外的一篇博客翻到的。

1 Array.prototype.unique = function() {
2     var o = {}, i, l = this.length, r = [];
3     for(i=0; i<l;i+=1) o[this[i]] = this[i];
4     for(i in o) r.push(o[i]);
5     return r;
6 };

这个方法的关键点在于 o[this[i]] = this[i] 重复的值会被自己覆盖掉,所以最终只会保留一个,最后通过for-in,push到一个新数组中,再返回出去。

另一个办法,比较经典,双层for循环,然后用===去判断是否重复。

1 Array.prototype.unique = function() {
2     var a = [], l = this.length;
3     for(var i=0; i<l; i++) {
4       for(var j=i+1; j<l; j++)
5             if (this[i] === this[j]) j = ++i;
6       a.push(this[i]);
7     }
8     return a;
9 };