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

 更新时间:2020年08月03日 14:33:20   作者:小宁同学  
这篇文章主要介绍了js数组中去除重复值的几种方法,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下

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

  去除数组重复值方法:

    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数组去除重复值的资料请关注脚本之家其它相关文章!

相关文章

  • 微信小程序自定义select下拉选项框的方法

    微信小程序自定义select下拉选项框的方法

    这篇文章主要为大家详细介绍了微信小程序自定义select下拉选项框的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-05-05
  • 全面了解函数声明与函数表达式、变量提升

    全面了解函数声明与函数表达式、变量提升

    下面小编就为大家带来一篇全面了解函数声明与函数表达式、变量提升。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2016-08-08
  • javascript强大的日期函数代码分享

    javascript强大的日期函数代码分享

    这篇文章介绍了javascript强大的日期函数代码,有需要的朋友可以参考一下
    2013-09-09
  • js实现按一下删除键删除整个单词附demo

    js实现按一下删除键删除整个单词附demo

    使用代码实现当删除单词时就一次性删除整个单词,有个demo,相信大家看过之后就知道是什么意思了
    2014-09-09
  • js setTimeout实现延迟关闭弹出层

    js setTimeout实现延迟关闭弹出层

    有时候我们希望弹出层能够实现延迟关闭,并且鼠标在弹出层区域移动的时候能够保持显现,下面是具体的实现代码。
    2010-04-04
  • javascript中Promise使用详解

    javascript中Promise使用详解

    这篇文章主要介绍了javascript中Promise使用详解,关于Promise的使用相关的知识点下面文章内容介绍详细具有一定的参考价值,需要的小伙伴可以参考一下
    2022-04-04
  • JS字符串常用操作方法实例小结

    JS字符串常用操作方法实例小结

    这篇文章主要介绍了JS字符串常用操作方法,结合实例形式总结分析了javascript字符串获取、返回、拼接、替换、搜索、计算等相关操作技巧,需要的朋友可以参考下
    2019-06-06
  • JS数组实现分类统计实例代码

    JS数组实现分类统计实例代码

    本文通过实例代码给大家介绍了js数组实现分类统计的相关知识,非常不错,具有一定的参考借鉴价值,需要的朋友可以参考下
    2018-09-09
  • JavaScript Canvas编写炫彩的网页时钟

    JavaScript Canvas编写炫彩的网页时钟

    这篇文章主要为大家详细介绍了JavaScript Canvas编写炫彩的网页时钟,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-10-10
  • JS封装cavans多种滤镜组件

    JS封装cavans多种滤镜组件

    这篇文章主要介绍了JS封装cavans多种滤镜组件,本文主要是讲解图片滤镜的效果以及实现思路,如需更多的滤镜效果可以研究算法或者参考其他的一些开源库glfx.js、lena.js等等,需要的朋友可以参考下
    2022-02-02

最新评论