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数组去除重复值的资料请关注脚本之家其它相关文章!
相关文章
不到200行 JavaScript 代码实现富文本编辑器的方法
这篇文章主要介绍了不到200行 JavaScript 代码实现富文本编辑器的方法,需要的朋友可以参考下2018-01-01ng-options和ng-checked在表单中的高级运用(推荐)
AngularJS是当前非常的流行的前端框架,它的语法糖非常多,也极大的方便了前端开发者。这篇文章主要介绍了ng-options和ng-checked在表单中的高级运用,需要的朋友可以参考下2017-01-01微信小程序开发实现的选项卡(窗口顶部/底部TabBar)页面切换功能图文详解
这篇文章主要介绍了微信小程序开发实现的选项卡(窗口顶部/底部TabBar)页面切换功能,结合图文与实例形式详细分析了微信小程序选项卡切换相关操作实现技巧,需要的朋友可以参考下2019-05-05详解JavaScript私有类字段和TypeScript私有修饰符
这篇文章主要介绍了JavaScript私有类字段和TypeScript私有修饰符,对私有类感兴趣的同学,可以参考下2021-04-04
最新评论