LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

JavaScript七个数组去重方法

admin
2024年7月20日 21:24 本文热度 587

在JavaScript中,去除数组中重复元素的需求十分常见,下面详细介绍并演示七种不同的去重方法,每种方法都会附带必要的代码注释。

1. 使用ES6的Set结构

Set是一种集合数据结构,它不允许有重复的元素。通过扩展运算符...可以轻松地将Set转换回数组,从而达到去重的目的。

// 原始数组
const arr = [1988725333231454445522];

// 定义去重函数
function removeDuplicatesWithSet(arr{
    // 创建一个Set,自动去除重复元素
    const uniqueSet = new Set(arr);
    // 使用扩展运算符将Set转换为数组
    const uniqueArray = [...uniqueSet];
    return uniqueArray;
}

// 调用函数并打印结果
const result = removeDuplicatesWithSet(arr);
console.log(result);

2. 使用filter()方法

filter()方法会创建一个新数组,其结果是通过提供的函数实现数组中的每个元素的筛选。

const arr = ['apple''apps''pear''apple''orange''apps'];

function removeDuplicatesWithFilter(arr{
    // 使用filter方法,只有当元素的索引和元素首次出现的位置相同时,才保留该元素
    return arr.filter((item, index) => arr.indexOf(item) === index);
}

const result = removeDuplicatesWithFilter(arr);
console.log(result);

3. 使用for循环和indexOf()

这种方法遍历数组,使用indexOf()检查元素是否已经存在于结果数组中。

const arr = [1988725333231454445522];

function removeDuplicatesWithFor(arr{
    const uniqueArray = []; // 初始化一个空数组用于存放唯一元素
    for (let i = 0; i < arr.length; i++) {
        // 如果元素尚未在uniqueArray中出现,则添加之
        if (uniqueArray.indexOf(arr[i]) === -1) {
            uniqueArray.push(arr[i]);
        }
    }
    return uniqueArray;
}

const result = removeDuplicatesWithFor(arr);
console.log(result);

4. 双重for循环去重

尽管这种方法可以工作,但它效率低下,不推荐使用,尤其是对于大型数组。

const arr = [1988725333231454445522];

function removeDuplicatesWithDoubleFor(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--; // 由于splice改变了数组长度,所以需要减一以保持正确的索引
            }
        }
    }
    return arr;
}

const result = removeDuplicatesWithDoubleFor(arr);
console.log(result);

5. 使用indexOf()与新数组

这种方法检查元素在原始数组中的首次出现位置,如果该位置与当前索引匹配,则添加到新数组中。

const arr = [1988725333231454445522];

function removeDuplicatesWithIndexOf(arr{
    const uniqueArray = [];
    for (let i = 0; i < arr.length; i++) {
        // 只有当元素首次出现时才添加到uniqueArray中
        if (arr.indexOf(arr[i]) === i) {
            uniqueArray.push(arr[i]);
        }
    }
    return uniqueArray;
}

const result = removeDuplicatesWithIndexOf(arr);
console.log(result);

6. 使用includes()方法

includes()方法检查数组中是否存在指定的值,如果存在则返回true,否则返回false

const arr = [1988725333231454445522];

function removeDuplicatesWithIncludes(arr{
    const uniqueArray = [];
    for (let i = 0; i < arr.length; i++) {
        // 如果uniqueArray中不包含当前元素,则添加之
        if (!uniqueArray.includes(arr[i])) {
            uniqueArray.push(arr[i]);
        }
    }
    return uniqueArray;
}

const result = removeDuplicatesWithIncludes(arr);
console.log(result);

7. 使用reduce()方法

reduce()方法对数组中的每个元素执行一个由您提供的reducer函数,将其结果汇总为单个返回值。

const arr = [1988725333231454445522];

function removeDuplicatesWithReduce(arr{
    // reducer函数,检查acc(累加器)中是否已经包含当前元素,如果没有,则添加
    return arr.reduce((acc, curr) => {
        if (!acc.includes(curr)) {
            acc.push(curr);
        }
        return acc;
    }, []);
}

const result = removeDuplicatesWithReduce(arr);
console.log(result);

每种方法都有其适用场景和性能特点,选择最适合的方法取决于具体的项目需求和环境。通常,使用ES6的Setfilter()方法是最佳选择,因为它们既简洁又高效。


该文章在 2024/7/22 11:47:20 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2024 ClickSun All Rights Reserved