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


Posted in Javascript onAugust 03, 2020

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

去除数组重复值方法:

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数组去除重复值的资料请关注三水点靠木其它相关文章!

Javascript 相关文章推荐
JS判断页面加载状态以及添加遮罩和缓冲动画的代码
Oct 11 Javascript
一个仿糯米弹框效果demo
Jul 22 Javascript
JS遍历数组及打印数组实例分析
Jan 21 Javascript
轻松掌握JavaScript状态模式
Sep 07 Javascript
浅析Node.js:DNS模块的使用
Nov 23 Javascript
JavaScript之DOM插入更新删除_动力节点Java学院整理
Jul 03 Javascript
ComboBox(下拉列表框)通过url加载调用远程数据的方法
Aug 06 Javascript
vue-video-player 通过自定义按钮组件实现全屏切换效果【推荐】
Aug 29 Javascript
基于Vue实现可以拖拽的树形表格实例详解
Oct 18 Javascript
详解vue-cli+element-ui树形表格(多级表格折腾小计)
Apr 17 Javascript
JS实现打砖块游戏
Feb 14 Javascript
JavaScript中使用Spread运算符的八种方法总结
Jun 18 Javascript
Vue打包部署到Nginx时,css样式不生效的解决方式
Aug 03 #Javascript
javascript运行机制之执行顺序理解
Aug 03 #Javascript
解决vue+elementui项目打包后样式变化问题
Aug 03 #Javascript
vue实现PC端分辨率适配操作
Aug 03 #Javascript
浅谈JavaScript中的“!!”作用
Aug 03 #Javascript
基于脚手架创建Vue项目实现步骤详解
Aug 03 #Javascript
解决Vue的项目使用Element ui 走马灯无法实现的问题
Aug 03 #Javascript
You might like
php中使用gd库实现下载网页中所有图片
2015/05/12 PHP
yii2 url重写并隐藏index.php方法
2018/12/10 PHP
JavaScript中的数组操作介绍
2014/12/30 Javascript
使用jquery清空、复位整个输入域
2015/04/02 Javascript
7个去伪存真的JavaScript面试题
2016/01/07 Javascript
javascript的BOM
2016/05/03 Javascript
jQuery插件zTree实现清空选中第一个节点所有子节点的方法
2017/03/08 Javascript
JavaScript30 一个月纯 JS 挑战中文指南(英文全集)
2017/07/23 Javascript
Vue2(三)实现子菜单展开收缩,带动画效果实现方法
2019/04/28 Javascript
vue(2.x,3.0)配置跨域代理
2019/11/27 Javascript
Python cookbook(字符串与文本)针对任意多的分隔符拆分字符串操作示例
2018/04/19 Python
django将图片上传数据库后在前端显式的方法
2018/05/25 Python
Python使用sqlalchemy模块连接数据库操作示例
2019/03/13 Python
关于Python-faker的函数效果一览
2019/11/28 Python
Python+appium框架原生代码实现App自动化测试详解
2020/03/06 Python
Pycharm新手使用教程(图文详解)
2020/09/17 Python
python自动从arxiv下载paper的示例代码
2020/12/05 Python
CSS3中31种选择器使用方法教程
2013/12/05 HTML / CSS
阳光体育:Sunny Sports(购买露营和远足设备)
2018/08/07 全球购物
女士时装鞋:Chinese Laundry
2018/08/29 全球购物
工厂厂长的职责
2013/12/12 职场文书
军神教学反思
2014/02/04 职场文书
文案策划求职信
2014/03/18 职场文书
仓库文员岗位职责
2014/04/06 职场文书
2014年图书馆工作总结
2014/11/25 职场文书
2015欢度元旦标语口号
2014/12/09 职场文书
学校食品安全责任书
2015/01/29 职场文书
商场圣诞节活动总结
2015/05/06 职场文书
环保守法证明
2015/06/24 职场文书
篮球赛闭幕式主持词
2015/07/03 职场文书
承诺书的签字人,需不需要承担相应的责任?
2019/07/09 职场文书
react合成事件与原生事件的相关理解
2021/05/13 Javascript
Python NumPy灰度图像的压缩原理讲解
2021/08/04 Python
Redis字典实现、Hash键冲突及渐进式rehash详解
2021/09/04 Redis
PyTorch中的torch.cat简单介绍
2022/03/17 Python
Mac电脑OS系统下安装Nginx的详细教程
2022/04/14 Servers