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集合将要去重的数组作为参数传进去,然后创建⼀个新数组,循环遍历⼀下集合,将每个集合元素添加到新数组,最后将新数组返回即可
jsarray删除元素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数组去除重复值的资料请关注其它相关⽂章!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论