关于js数组去重的五种方法

本文介绍了JavaScript中去除数组重复元素的五种方法:Set、indexOf、双重循环、filter和forEach。通过实例代码展示了每种方法的实现过程及效果,帮助理解不同方法的适用场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.Set方法

//定义一个数组
var arr = [2,2,3,3,4,4];
var newArr= new Set(arr)
//打印
console.log(newArr) //2,3,4

2.indexOf方法

indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置。找不到指定元素则返回-1.

var arr = [2,2,3,3,4,4]
var newArr = []
for(var i=0; i<arr.length; i++){
    if( newArr.indexOf(arr[i]) == -1){
        newArr.push(arr[i])
    }
}
console.log(newArr)
    

3.for循环

var arr = [3,3,4,4,5,5]
for(var i=0; i<arr.length; i++){
    for(var j=i+1; j<arr.length; j++){
        if(arr[i] == arr[j]){
            arr.splice(j,1)
             j--
        }
    }
}

console.log(arr)//3,4,5

4.filter方法

var arr = [2,2,3,3,4,4]
var newArr = arr.filter((item,index,array)=>{
       return arr.indexOf(item) == index
})    
console.log(newArr )

5.forEach方法(和filter方法差不多,但是forEach方没有返回值)

var arr = [2,2,3,3,4,4]
var newArr = []
arr.forEach((item,index,array) => {
    arr.indexOf(item) == index
    newArr.push(item)
})

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值