0

0

js数组去重的方法有哪些

zbt

zbt

发布时间:2023-08-09 16:47:45

|

1365人浏览过

|

来源于php中文网

原创

js数组去重的方法有使用Set、使用indexOf、使用includes、使用filter和使用reduce。1、使用Set,特点是集合中的元素不会重复;2、使用indexOf,可以返回指定元素在数组中的第一个索引位置;3、使用includes,可以用来判断一个元素是否已经存在于数组中;4、使用filter,可以用来筛选元素;5、使用reduce,可以将数组中的元素压缩等等。

js数组去重的方法有哪些

本教程操作环境:windows10系统、JavaScript ES12版本、DELL G3电脑。

在JavaScript编程中,我们经常会遇到需要对数组进行去重操作的情况。去重是指将数组中重复的元素去除,只保留其中的一个。本文将介绍一些常用的JavaScript数组去重方法,以帮助读者更好地理解和应用。

方法一:使用Set

ES6中引入的Set对象是一种新的数据结构,它可以帮助我们快速进行数组去重。Set对象的特点是集合中的元素不会重复。我们可以简单地将数组转换为Set对象,然后再将Set对象转换回数组,从而达到去重的目的。

示例代码:

let arr = [1, 2, 2, 3, 3, 4, 5];
let uniqueArr = Array.from(new Set(arr));
console.log(uniqueArr); // [1, 2, 3, 4, 5]

方法二:使用indexOf

JavaScript中的数组对象提供了一个indexOf方法,它可以返回指定元素在数组中的第一个索引位置。我们可以利用此方法来判断一个元素是否已经存在于新的数组中,如果不存在,则将其添加进去。

示例代码:

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

方法三:使用includes

ES7中引入的includes方法与indexOf方法类似,它可以用来判断一个元素是否已经存在于数组中。我们可以利用这个方法来进行数组去重操作。

Fortran基本用法小结 WORD版
Fortran基本用法小结 WORD版

本文档主要讲述的是Fortran基本用法小结;希望能够给学过C但没有接触过Fortran的同学带去一些帮助。Fortran是一种编程语言。它是世界上最早出现的计算机高级程序设计语言,广泛应用于科学和工程计算领域。FORTRAN语言以其特有的功能在数值、科学和工程计算领域发挥着重要作用。Fortran奠定了高级语言发展的基础。现在Fortran在科研和机械方面应用很广。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载

示例代码:

let arr = [1, 2, 2, 3, 3, 4, 5];
let uniqueArr = [];
for (let i = 0; i < arr.length; i++) {
if (!uniqueArr.includes(arr[i])) {
uniqueArr.push(arr[i]);
}
}
console.log(uniqueArr); // [1, 2, 3, 4, 5]

方法四:使用filter

JavaScript中的数组对象提供了一个filter方法,它可以用来筛选元素。我们可以利用这个方法来进行数组去重操作,只保留第一次出现的元素。

示例代码:

let arr = [1, 2, 2, 3, 3, 4, 5];
let uniqueArr = arr.filter((item, index) => {
return arr.indexOf(item) === index;
});
console.log(uniqueArr); // [1, 2, 3, 4, 5]

方法五:使用reduce

JavaScript中的数组对象提供了一个reduce方法,它可以将数组中的元素“压缩”为一个单独的值。我们可以利用这个方法来进行数组去重操作。

示例代码:

let arr = [1, 2, 2, 3, 3, 4, 5];
let uniqueArr = arr.reduce((prev, curr) => {
if (!prev.includes(curr)) {
prev.push(curr);
}
return prev;
}, []);
console.log(uniqueArr); // [1, 2, 3, 4, 5]

结论:

本文介绍了JavaScript中常用的数组去重方法,其中包括使用Set、indexOf、includes、filter和reduce等方法。读者可以根据实际情况选择合适的方法来进行数组去重操作。在实际开发中,数组去重是一项非常基础和常用的操作,掌握了这些方法,可以更高效地处理数组数据,提升程序的性能和可读性 。

相关专题

更多
菜鸟裹裹入口以及教程汇总
菜鸟裹裹入口以及教程汇总

本专题整合了菜鸟裹裹入口地址及教程分享,阅读专题下面的文章了解更多详细内容。

0

2026.01.22

Golang 性能分析与pprof调优实战
Golang 性能分析与pprof调优实战

本专题系统讲解 Golang 应用的性能分析与调优方法,重点覆盖 pprof 的使用方式,包括 CPU、内存、阻塞与 goroutine 分析,火焰图解读,常见性能瓶颈定位思路,以及在真实项目中进行针对性优化的实践技巧。通过案例讲解,帮助开发者掌握 用数据驱动的方式持续提升 Go 程序性能与稳定性。

9

2026.01.22

html编辑相关教程合集
html编辑相关教程合集

本专题整合了html编辑相关教程合集,阅读专题下面的文章了解更多详细内容。

56

2026.01.21

三角洲入口地址合集
三角洲入口地址合集

本专题整合了三角洲入口地址合集,阅读专题下面的文章了解更多详细内容。

51

2026.01.21

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

397

2026.01.21

妖精漫画入口地址合集
妖精漫画入口地址合集

本专题整合了妖精漫画入口地址合集,阅读专题下面的文章了解更多详细内容。

118

2026.01.21

java版本选择建议
java版本选择建议

本专题整合了java版本相关合集,阅读专题下面的文章了解更多详细内容。

3

2026.01.21

Java编译相关教程合集
Java编译相关教程合集

本专题整合了Java编译相关教程,阅读专题下面的文章了解更多详细内容。

16

2026.01.21

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

11

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Django 教程
Django 教程

共28课时 | 3.4万人学习

Excel 教程
Excel 教程

共162课时 | 12.9万人学习

MongoDB 教程
MongoDB 教程

共17课时 | 2.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号