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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
为了去除动态数组重复元素,有几种方法可以使用。以下是其的几种方法方法一:使用Set 通过将动态数组转换为Set,可以自动去除重复元素。Set是一种无序且不重复的数据结构。你可以通过将动态数组转换为Set,然后再将其转回数组来实现去重的目的。 方法二:使用filter和indexOf 使用filter和indexOf组合的技巧可以实现去除动态数组重复元素。你可以通过定义一个过滤器函数,在每次遍历数组时检查元素是否已经在结果数组。如果元素已经存在,则忽略它;如果元素不存在,则将其添加到结果数组方法三:使用reduce和includes 使用reduce和includes方法也可以实现去除动态数组重复元素。你可以通过定义一个累加器函数,在每次遍历数组时检查元素是否已经在累加器。如果元素已经存在,则忽略它;如果元素不存在,则将其添加到累加器。 以上是几种常见的方法,你可以根据具体情况选择最适合的方法去除动态数组重复元素。<span class="em">1</span><span class="em">2</span> #### 引用[.reference_title] - *1* [JavaScript移除数组重复元素方法](https://download.csdn.net/download/weixin_38641764/13034334)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [LabVIEW 删除数组重复元素实例](https://download.csdn.net/download/wzw_8888/13210989)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值