js数组中去除重复值的几种方法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
去除数组重复值方法:
 
    1,利用indexOf()方法去除
 
    思路:创建一个新数组,然后循环要去重的数组,然后用新数组去找要去重数组的值,如果找不到则使用.push添加到新数组,最后把新数组返回回去就行了
 
       看不懂没关系,上代码就比较容易懂了
     
function fun(arr){
 let newsArr = [];
 for (let i = 0; i < arr.length; i++) {
  if(newsArr.indexOf(arr[i]) === -1){
   newsArr.push(arr[i]);
  }
 }
 return newsArr;
}
 
    2,利用splice方法去除
 
    思路:这个方法有点模仿冒泡  俩层循环,外层循环遍历数组,内层循环比较值,如果有相同, 则使用splice去除 然后返回处理完的数组即可
 
       看不懂没关系,上代码就比较容易懂了
     
function fun(arr){
 for (let i = 0; i < arr.length; i++) {
  for(let j = i+1; j < arr.length; j++){
   if(arr[i]==arr[j]){
    arr.splice(j,1);          j--;
   }
  }
 }
 return arr;
}
 
    3,利用es6新增的集合Set去除
 
    这里简单介绍一下Set 集合,他跟数组很相识,但不是数组,是集合。他里面也有跟多方法,如增(add),删(delete),查(has)等等。
 
    他最重要的特点是:元素不能重复,即在Set集合不会出现相同的元素
 
    Set去重方案1
 
    思路:因为Set集合里面不允许出现重复值,那我们就可以利用这个特点将我们的数组传进去去重
 
       首先new一个Set集合将要去重的数组作为参数传进去,然后创建一个新数组,循环遍历一下集合,将每个集合元素添加到新数组,最后将新数组返回即可
     
function fun(arr){
 let s1 = new Set(arr);
 let arr2 = [];
 for(let item of s1){
  arr2.push(item);
 }
 return arr2;
}
 
    Set去重方案2(使用数组方法Array.form()):
 
    思路:Array.from(); 能够把伪数组,集合转成数组类型,这个方法配合上Set集合就刚好符合我们的需求
     
function fun(arr){
 let s1 = new Set(arr);
 return Array.from(s1);
}
 
    Set去重方案3(使用es6展开运算符...):
 
    思路:es6展开运算符能够将一个数组转为用逗号分隔的参数序列
     
function fun(arr){
 let s1 = new Set(arr);
 return [...s1];
}

 

posted @   锐洋智能  阅读(2641)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· 【.NET】调用本地 Deepseek 模型
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
· 上周热点回顾(2.17-2.23)
· 如何使用 Uni-app 实现视频聊天(源码,支持安卓、iOS)
历史上的今天:
2014-01-22 LoadRunner 11 安装及破解
2014-01-22 关于人人网开发框架
2009-01-22 实现一个获取元素样式的函数getStyle
点击右上角即可分享
微信分享提示