网上关于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]