JS 数组去重的几个方法
2015-04-09 19:20
190 查看
Array.prototype.unique1 = function () { var n = []; //一个新的临时数组 for (var i = 0; i < this.length; i++) //遍历当前数组 { //如果当前数组的第i已经保存进了临时数组,那么跳过, //否则把当前项push到临时数组里面 if (n.indexOf(this[i]) == -1) n.push(this[i]); } return n; }; Array.prototype.unique2 = function() { var n = {},r=[]; //n为hash表,r为临时数组 for(var i = 0; i < this.length; i++) //遍历当前数组 { if (!n[this[i]]) //如果hash表中没有当前项 { n[this[i]] = true; //存入hash表 r.push(this[i]); //把当前数组的当前项push到临时数组里面 } } return r; }; Array.prototype.unique3 = function() { var n = [this[0]]; //结果数组 for(var i = 1; i < this.length; i++) //从第二项开始遍历 { //如果当前数组的第i项在当前数组中第一次出现的位置不是i, //那么表示第i项是重复的,忽略掉。否则存入结果数组 if (this.indexOf(this[i]) == i) n.push(this[i]); } return n; }; Array.prototype.unique4 = function() { this.sort(); var re=[this[0]]; for(var i = 1; i < this.length; i++) { if( this[i] !== re[re.length-1]) { re.push(this[i]); } } return re; }; var arr = [1,2,2,2,3,3,4,5]; console.log(arr.unique1()); // [1, 2, 3, 4, 5] console.log(arr.unique2()); // [1, 2, 3, 4, 5] console.log(arr.unique3()); // [1, 2, 3, 4, 5] console.log(arr.unique4()); // [1, 2, 3, 4, 5]
相关文章推荐
- JS从数组中随机取出几个数组元素的方法
- js中数组和字符串常用的几个方法
- js向一个数组中插入元素的几个方法-性能比较
- 几个关于js数组方法reduce的经典片段
- 关于JS中把二维数组变为一个数组的几个方法
- 总结几个jsvaScript 数组排序方法
- 几个关于js数组方法reduce的经典片段
- JS数组的几个常用方法
- js 数组去重的几个方法
- 几个JS方法
- Js:数组的各种方法范例pop,push,unshift,splice,shift
- js 所有数组方法
- 请高手指点,简单的几个数组操作方法不知道是否可以有更好的改进方法或者更简单的方法?
- SQL字符串数组操作几个方法[转帖]
- 几个WEB中常用的js方法 (转)
- JS数组方法汇总 array数组元素的添加和删除
- js 删除数组几种方法
- js获取屏幕高度和宽度的几个方法
- 自己写的JS数组插入方法
- JS数组方法汇总 array数组元素的添加和删除