在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 };