zl程序教程

您现在的位置是:首页 >  Javascript

当前栏目

常用的几种数组去重方法

2023-03-09 22:03:17 时间

数组去重常用的几种方法:

定义基础数组变量

  1. let arr = [8,5,12,8,5,45,2,56,78,45,5,45], 
  2.     newArr = [] 

一、暴力双循环去重法

  1. for(let i = 0;i < arr.length;i++){ 
  2.   for(let j = i + 1;j < arr.length;j++){ 
  3.     if(arr[i] == arr[j]){ 
  4.       arr.splice(j,1) 
  5.       j-- 
  6.     } 
  7.   } 
  8. console.log(arr) // (7) [8, 5, 12, 45, 2, 56, 78] 

二、includes()去重法

  1. for(let i of arr){ 
  2.   if(!newArr.includes(i)){ 
  3.     newArr.push(i) 
  4.   }else
  5.     console.log(i + "重复了"
  6.   } 
  7. console.log(newArr) // (7) [8, 5, 12, 45, 2, 56, 78] 

三、filter()循环过滤法

  1. arr.filter((val,index) => { 
  2.   if(newArr.indexOf(val) < 0){ 
  3.     newArr.push(val) 
  4.   } 
  5. }) 
  6. console.log(newArr) // (7) [8, 5, 12, 45, 2, 56, 78] 

四、sort()排序法

  1. arr = arr.sort() // (12) [12, 2, 45, 45, 45, 5, 5, 5, 56, 78, 8, 8] 
  2. for(let i = 0;i < arr.length;i++){ 
  3.   if(i <= arr.length - 1 && arr[i] != arr[i + 1]){ 
  4.     newArr.push(arr[i]) 
  5.   } 
  6. console.log(newArr) // (7) [12, 2, 45, 5, 56, 78, 8] 

五、ES6 Array.from()方法

  1. console.log(Array.from(new Set(arr))) // (7) [8, 5, 12, 45, 2, 56, 78] 
  2. console.log([...new Set(arr)]) // (7) [8, 5, 12, 45, 2, 56, 78](简写方法) 

六、递归去重

  1. let index = 0 
  2. arr = arr.sort() 
  3. function loop(index){ 
  4.   if(index > 1){ 
  5.     if(arr[index] == arr[index - 1]){ 
  6.       arr.splice(index,1) 
  7.     } 
  8.     index-- 
  9.     loop(index
  10.   } 
  11. loop(arr.length - 1) 
  12. console.log(arr) // (7) [12, 2, 45, 5, 56, 78, 8]