网站首页 > 精选教程 正文
数组去重在前端开发中非常有用,在很多业务场景中都有需要。我们都知道JavaScript实现数组去重的方式有很多,今天就汇总一下这些方法,方便大家比较选用。
1.使用Set数据结构
set是ES6新增的数据结构,特点就是集合内没有重复元素。正好可以利用这一特性实现数组去重。
const source = [1,1,2,2,3,3,4,4,5,5];
const unique = [...new Set(source)];
console.log(unique); // [1,2,3,4,5]
将Set转为数组,除了使用上面的展开操作符,也可以使用 Array.form() 方法。
这个方法写法简洁,是目前较常使用的数组去重方式。
2.比较索引位置是否一致
const source = [1,1,2,2,3,3,4,4,5,5];
const unique = source.filter((num,index) => {
return source.indexOf(num) === index;
});
console.log(unique); // [1,2,3,4,5]
这个方法的核心是比较元素位置和索引位置是否一致。因为 indexOf 只会返回第一个匹配元素的索引,如果有重复元素,第二个元素的索引必然和 indexOf 返回值不相等。
3.使用 includes 判断
const source = [1,1,2,2,3,3,4,4,5,5];
const unique = [];
for (const item of source) {
if (!unique.includes(item)) {
unique.push(item)
}
}
console.log(unique); // [1,2,3,4,5]
这种办法很好理解,遍历元素,判断元素是否在新数组中。如果不在新数组中,则说明是非重复元素,添加到新数组中。
遍历的方式可以有多种,for forEach 或者数组的其他方法都可以。
关于数组去重你还有什么方法,欢迎留言分享~
欢迎点赞,评论,转发 ~
- 上一篇: 【HarmonyOS Next之旅】ArkTS语法(一)
- 下一篇: JS数组过滤元素的方法
猜你喜欢
- 2025-05-23 C# 动态数组(ArrayList)
- 2025-05-23 C# 7.0中的Discard 变量:简化代码的利器
- 2025-05-23 JS数组过滤元素的方法
- 2025-05-23 【HarmonyOS Next之旅】ArkTS语法(一)
- 2025-05-23 C/C++编程笔记:帮你整理了"数组"的知识点!赶紧收藏
- 2025-05-23 Java 基础(四)集合源码解析 List
- 2025-05-23 Java中数组的声明和初始化方法
- 2025-05-23 数组、链表、队列和栈,四大基础数据结构详解
- 2025-05-23 最快清除数组空值?分享 1 段优质 JS 代码片段!
- 2025-05-23 【算法题】1574. 删除最短的子数组使剩余数组有序
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- nginx反向代理 (57)
- nginx日志 (56)
- nginx限制ip访问 (62)
- mac安装nginx (55)
- java和mysql (59)
- java中final (62)
- win10安装java (72)
- java启动参数 (64)
- java链表反转 (64)
- 字符串反转java (72)
- java逻辑运算符 (59)
- java 请求url (65)
- java信号量 (57)
- java定义枚举 (59)
- java字符串压缩 (56)
- java中的反射 (59)
- java 三维数组 (55)
- java插入排序 (68)
- java线程的状态 (62)
- java异步调用 (55)
- java中的异常处理 (62)
- java锁机制 (54)
- java静态内部类 (55)
- java怎么添加图片 (60)
- java 权限框架 (55)
本文暂时没有评论,来添加一个吧(●'◡'●)