当前位置: 移动技术网 > IT编程>开发语言>JavaScript > js数组中去除重复值的几种方法

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

2020年08月16日  | 移动技术网IT编程  | 我要评论
在日常开发中,我们可能会遇到将一个数组中里面的重复值去除,那么,我就将我自己所学习到的几种方法分享出来  去除数组重复值方法:    1,利用indexof()方法去除    思路:创建一个新数组,然

在日常开发中,我们可能会遇到将一个数组中里面的重复值去除,那么,我就将我自己所学习到的几种方法分享出来

  去除数组重复值方法:

    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];
}

以上就是js数组中去除重复值的几种方法的详细内容,更多关于js数组去除重复值的资料请关注移动技术网其它相关文章!

如您对本文有疑问或者有任何想说的,请 点击进行留言回复,万千网友为您解惑!

相关文章:

验证码:
移动技术网