js实现数组去重简洁代码(filter,Set,reduce)

1、通过filter实现数组去重

filter中传入的函数有三个参数。第一个item表示当前元素的值,第二个index表示当前元素的索引值,第三个self表示当前元素属于的数组对象。

var arr = [2,4,3,3,4,2,3,254,234,4];
function unique(arr) {
    return arr.filter((item, index, self) => {
        return self.indexOf(item) == index;
    })
}
console.log(unique(arr))

2、通过ES6新增的数据结构Set来实现数组去重

var arr = [2,4,3,3,4,2,3,254,234,4];
function unique(arr) {
    var x = new Set(arr);
    return [...x]
}
console.log(unique(arr))

3、通过reduce函数来实现数组去重

// reduce 方法
// arr.reduce(function(prev, cur, index, arr) {
//     // code...
// }, init);

/**
 * 其中,arr 表示原数组
 * prev 表示上一次调用回调时候的返回值,或者初始值init;
 * cur 表示当前正在处理的数组元素;
 * index 表示当前正在处理的数组元素的索引,若提供init值,则索引为0.否则索引为1;
 */
var arr = [2,3,24,2,4,24,252,3,2];
var newArr = arr.reduce((prev, cur) => {
    prev.indexOf(cur) == -1 && prev.push(cur);
    return prev;
}, []);

console.log(newArr); // [2,3,24,4,252]

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值