方法一:

双层循环,外层循环元素,内层循环时比较值,如果有相同的值则跳过,不相同则push进数组。

 Array.prototype.distinct = function(){
var arr = this,result = [],i,j,len = arr.length;
for(i = 0; i < len; i++){
for(j = i + 1; j < len; j++){
  if(arr[i] === arr[j]){
        j = ++i;
       }
     }
     result.push(arr[i]);
  }
  return result;
}
var arra = [1,2,3,4,4,1,1,2,1,1,1];
arra.distinct(); //返回[3,4,2,1]

方法二:利用splice直接在原数组进行操作
双层循环,外层循环元素,内层循环时比较值,值相同时,则删去这个值。
注意删除元素之后,需要将数组的长度也减1.

 Array.prototype.distinct = function() {
var arr = this,
i, j, len = arr.length;
for (i = 0; i < len; i++) {
for (j = i + 1; j < len; j++) {
if (arr[i] == arr[j]) {
arr.splice(j, 1);
len--;
j--;
}
}
}
return arr;
};
var a = [1, 2, 3, 4, 5, 6, 5, 3, 2, 4, 56, 4, 1, 2, 1, 1, 1, 1, 1, 1, ];
var b = a.distinct();
console.log(b.toString()); //1,2,3,4,5,6,56

优点:简单易懂
缺点:占用内存高,速度慢

方法三:利用对象的属性不能相同的特点进行去重

 Array.prototype.distinct = function() {
var arr = this,
i, obj = {},
result = [],
len = arr.length;
for (i = 0; i < arr.length; i++) {
if (!obj[arr[i]]) { //如果能查找到,证明数组元素重复了
obj[arr[i]] = 1;
result.push(arr[i]);
}
}
return result;
};
var a = [1, 2, 3, 4, 5, 6, 5, 3, 2, 4, 56, 4, 1, 2, 1, 1, 1, 1, 1, 1, ];
var b = a.distinct();
console.log(b.toString()); //1,2,3,4,5,6,56

方法四:数组递归去重
运用递归的思想,先排序,然后从最后开始比较,遇到相同,则删除。

 Array.prototype.distinct = function() {
var arr = this,
len = arr.length;
arr.sort(function(a, b) { //对数组进行排序才能方便比较
return a - b;
}) function loop(index) {
if (index >= 1) {
if (arr[index] === arr[index - 1]) {
arr.splice(index, 1);
}
loop(index - 1); //递归loop函数进行去重
}
}
loop(len - 1);
return arr;
};
var a = [1, 2, 3, 4, 5, 6, 5, 3, 2, 4, 56, 4, 1, 2, 1, 1, 1, 1, 1, 1, 56, 45, 56];
var b = a.distinct();
console.log(b.toString()); //1,2,3,4,5,6,45,56

方法五:利用indexOf以及forEach

 Array.prototype.distinct = function() {
var arr = this,
result = [],
len = arr.length;
arr.forEach(function(v, i, arr) { //这里利用map,filter方法也可以实现
var bool = arr.indexOf(v, i + 1); //从传入参数的下一个索引值开始寻找是否存在重复
if (bool === -1) {
result.push(v);
}
})
return result;
};
var a = [1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 2, 3, 3, 2, 2, 1, 23, 1, 23, 2, 3, 2, 3, 2, 3];
var b = a.distinct();
console.log(b.toString()); //1,23,2,3

方法六:利用ES6的set
Set数据结构,它类似于数组,其成员的值都是唯一的。利用Array.from将Set结构转换成数组。

 function dedupe(array) {
return Array.from(new Set(array));
}
dedupe([1, 1, 2, 3]) //[1,2,3]

拓展运算符(...)内部使用for...of循环

 let arr = [1,2,3,3];
let resultarr = [...new Set(arr)];
console.log(resultarr); //[1,2,3]

下面给大家补充介绍合并数组并去重的方法

一、concat()方法
思路:concat() 方法将传入的数组或非数组值与原数组合并,组成一个新的数组并返回。该方法会产生一个新的数组。

 function concatArr(arr1, arr2){
  var arr = arr1.concat(arr2);
  arr = unique1(arr);//再引用上面的任意一个去重方法
  return arr;
}

二、Array.prototype.push.apply()
思路:该方法优点是不会产生一个新的数组。

var a = [1, 2, 3];
var b = [4, 5, 6];
Array.prototype.push.apply(a, b);//a=[1,2,3,4,5,6]
  //等效于:a.push.apply(a, b);
  //也等效于[].push.apply(a, b);
function concatArray(arr1,arr2){
   Array.prototype.push.apply(arr1, arr2);
     arr1 = unique1(arr1);
     return arr1;
}

最新文章

  1. Linux下的磁盘分割和文件系统
  2. MySql导出数据到csv
  3. cocos2d-x test学习[1]
  4. JS对象深刻理解 - 1
  5. maxscript,#号和$号
  6. while循环的跳出
  7. linux学习心得之目录树开端与/etc(图文)
  8. java Http消息传递之POST和GET两种方法--通过实用工具类来获取服务器资源
  9. 使用freemarker模板生成word文档
  10. 浅谈jQuery Pagination Ajax 分页插件的使用
  11. oracle 基础(上)
  12. golang自动构建脚本
  13. 【Git】+安装+使用+配置
  14. [springMvc] 源码分析笔记(二)
  15. CODEFORCES ROUND #761 ANALYSES BY TEAM:RED &amp; BLACK
  16. go-关于指针和地址
  17. day_6.10py面试题:访问百度的过程
  18. eclipse安装、汉化、搭建安卓开发环境
  19. 在有 UI 线程参与的同步锁(如 AutoResetEvent)内部使用 await 可能导致死锁
  20. Maven常用命令及Eclipse应用

热门文章

  1. 《java入门第一季》之泛型类引入
  2. 一台电脑上同启动两个Tomcat的方式,windows/Linux配置。
  3. BAT有增有减&amp;nbsp;互联网2015校园…
  4. Gitflow工作流程
  5. C++ Primer 有感(标准库pair)
  6. DBA Scripts
  7. shell快捷键
  8. SpriteBuilder中节点位置类型为百分比时不能定位的解决
  9. 《java入门第一季》之类String类小案例
  10. Memcached的配置,SSH项目中的整合(com.whalin),Memcached工具类,Memcached的代码调用