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 相关文章推荐
Javascript学习笔记2 函数
Jan 11 Javascript
javascript中的toFixed固定小数位数 简单实例分享
Jul 12 Javascript
js登录弹出层特效
Mar 07 Javascript
JavaScript中的console.dir()函数介绍
Dec 29 Javascript
jQuery 利用$.ajax 时获取原生XMLHttpRequest 对象的方法
Aug 25 Javascript
vue项目实现记住密码到cookie功能示例(附源码)
Jan 31 Javascript
JavaScript累加、迭代、穷举、递归等常用算法实例小结
May 08 Javascript
微信小程序网络层封装的实现(promise, 登录锁)
May 08 Javascript
JS计算两个数组的交集、差集、并集、补集(多种实现方式)
May 21 Javascript
jQuery操作事件完整实例分析
Jan 10 jQuery
ng-alain的sf如何自定义部件的流程
Jun 12 Javascript
Vue3实现简易音乐播放器组件
Aug 14 Vue.js
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快速查找数据库中恶意代码的方法
2015/04/01 PHP
PHP-FPM运行状态的实时查看及监控详解
2016/11/18 PHP
InnerHtml和InnerText的区别分析
2009/03/13 Javascript
基于jQuery的固定表格头部的代码(IE6,7,8测试通过)
2010/05/18 Javascript
鼠标事件延时切换插件
2011/03/12 Javascript
利用ajaxfileupload插件实现文件上传无刷新的具体方法
2013/06/08 Javascript
快速解决jquery之get缓存问题的最简单方法介绍
2013/12/19 Javascript
javascript实现的弹出层背景置灰-模拟(easyui dialog)
2013/12/27 Javascript
Javascript实现的SHA-256加密算法完整实例
2016/02/02 Javascript
Javascript字符串拼接小技巧(推荐)
2016/06/02 Javascript
bootstrap基础知识学习笔记
2016/11/02 Javascript
基于jquery实现多级菜单效果
2017/07/25 jQuery
微信小程序实现顶部普通选项卡效果(非swiper)
2020/06/19 Javascript
浅谈Angular HttpClient简单入门
2018/05/04 Javascript
微信小程序调用微信支付接口的实现方法
2019/04/29 Javascript
JS快速实现简单计算器
2020/04/08 Javascript
vue+element实现动态加载表单
2020/12/13 Vue.js
[01:10:03]OG vs EG 2018国际邀请赛淘汰赛BO3 第三场 8.23
2018/08/24 DOTA
Python简单删除目录下文件以及文件夹的方法
2015/05/27 Python
使用Django的模版来配合字符串翻译工作
2015/07/27 Python
python爬虫获取京东手机图片的图文教程
2017/12/29 Python
python3之模块psutil系统性能信息使用
2018/05/30 Python
使用Python快速制作可视化报表的方法
2019/02/03 Python
python SVM 线性分类模型的实现
2019/07/19 Python
Python封装成可带参数的EXE安装包实例
2019/08/24 Python
基于python中__add__函数的用法
2019/11/25 Python
Spartoo西班牙官网:法国时尚购物网站
2018/03/27 全球购物
亚洲最大的运动鞋寄售店:KicksCrew
2020/11/26 全球购物
护士专业推荐信
2013/11/02 职场文书
外语专业毕业生个人的自荐信
2013/11/19 职场文书
银行开业庆典方案
2014/02/06 职场文书
美容院经理岗位职责
2014/04/03 职场文书
公司合作意向书范文
2014/07/30 职场文书
银行员工考核评语
2014/12/31 职场文书
廉洁自律证明
2015/06/24 职场文书
8个JS的reduce使用实例和reduce操作方式
2021/10/05 Javascript