例1
利用双重复制来一个个判断然后删除
代码如下 | 复制代码 |
<script type="text/javascript"> <!-- Array.prototype.distinct = function() { var ret = []; for (var i = 0; i < this.length; i++) { for (var j = i+1; j < this.length;) { if (this[i] === this[j]) { ret.push(this.splice(j, 1)[0]); } else { j++; } } } return ret; } var haha=[1,"6",2,3,4,5,6,7,7,6,6,6]; alert(haha.distinct()+"|"+haha); --> </script> |
但是这个函数中使用了2个for循环,当数组数据多的情况下,效率肯定不行,下面我百度找到一个可以去除一个循环的办法
代码如下 | 复制代码 |
<script type="text/javascript"> <!-- Array.prototype.distinct=function(){ var tempobj={},temparr=[]; for(var i=0,items;(items=this[i])!=null;) { if(tempobj[items]!==items) { tempobj[items]=items; i++; } else { temparr.push(this.splice(i,1)[0]); } } return temparr; } var haha=[1,"6",2,3,4,5,6,7,7,6,6,6]; alert(haha.distinct()+"|"+haha); --> </script> |
可以看出结果是一样的,但是少了一个for循环,多了一个临时对象tempobj,效率肯定是大大提升了。原理就是把数组的值存入tempobj的属性及属性值,如果tempobj的属性值等于数组的值,就把该值从数组中删除并添加到temparr中。
最推荐的一种方法
代码如下 | 复制代码 |
function getnorepeat() { return arguments[0].join('‖').match(/(b[^‖]+b)(?!.*‖1b)/ig); } var tmparr = [1, 'a', 'ab', 'abc', 'd', 1.2, 'a+b', 'd', 'e', 5, 'www.111cn.net', 1, 'h', 'c', 'ab']; var retarr = getnorepeat(tmparr); alert(retarr); |
时间: 2024-10-27 15:46:10