JS数组去重

网上关于JS数组去重的方法很多,我这人比较懒,一般知道了一个最快速的,就不想再记那些慢的了。之前比较公认的一种快速方式是引用类似hash表的思想。代码如下:

 

 

var ddd = [1,2,4,5,2, 222,1,5,6];

var uq = {};
var rq = [];

for(var i=0; i<9; i++){
      if(!uq[ddd[i]]){
          uq[ddd[i]] = true;
          rq.push(ddd[i]);
      }
}

return rq;

 

 

    但是这个方法有个很大的疏漏,就是没有考虑到 '222' 和 222 这种元素会被当作相同元素被剔除的情况。于是我做了如下的修改。

 

 

var ddd = [1,2,4,5,2, '222', 222,1,5,6];

var uq = {};
var rq = [];
var prefix = '';
for(var i=0; i<8; i++){
    if(typeof ddd[i] == 'string' ) {
        prefix = '_str';
    } else {
        prefix = '';
    }
    if(!uq[ddd[i]+prefix]){
        uq[ddd[i]+prefix] = true;
        rq.push(ddd[i]);
    }
}

return rq;

 

    没做什么高深的修改,就是加了个前缀,区分下。这样,结果就是 [1,2,4,5,'222', 222,6]

 

你可能感兴趣的:(js)