数组去重的7种方法

本文介绍了JavaScript中处理数组去重的7种方法,包括双循环、indexOf、相邻元素、对象属性、Set与解构赋值、Array.from与Set。讨论了前端处理去重的场景及其效率问题,提供了解决数组重复元素的实用技巧。
摘要由CSDN通过智能技术生成

方法实现

双循环去重

indexOf方法去重1

indexOf方法去重2

相邻元素去重

利用对象属性去重

set与解构赋值去重

Array.from与set去重


去重是开发中经常会碰到的一个热点问题,不过目前项目中碰到的情况都是后台接口使用SQL去重,简单高效,基本不会让前端处理去重。

那么前端处理去重会出现什么情况呢?假如每页显示10条不同的数据,如果数据重复比较严重,那么要显示10条数据,可能需要发送多个http请求才能够筛选出10条不同的数据,而如果在后台就去重了的话,只需一次http请求就能够获取到10条不同的数据。

当然,这并不是说前端去重就没有必要了,依然需要会熟练使用。本文主要介绍几种常见的数组去重的方法

方法实现


双循环去重

双重for(或while)循环是比较笨拙的方法,它实现的原理很简单:先定义一个包含原始数组第一个元素的数组,然后遍历原始数组,将原始数组中的每个元素与新数组中的每个元素进行比对,如果不重复则添加到新数组中,最后返回新数组;因为它的时间复杂度是O(n^2),如果数组长度很大,那么将会非常耗费内存

const arr = [20,66,50,30,20,66,50,80]

function unique(arr) {
    let res = [arr[0]]
    for (let i = 1; i < arr.length; i++) {
        let flag = true
        fo
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值