网站首页 > 技术文章 正文
数组去重在前端开发中非常有用,在很多业务场景中都有需要。我们都知道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 或者数组的其他方法都可以。
关于数组去重你还有什么方法,欢迎留言分享~
欢迎点赞,评论,转发 ~
猜你喜欢
- 2025-07-27 抛弃立即执行函数 (IIFE),拥抱现代 JavaScript 块级作用域
- 2025-05-05 28.ECMAScript 标准深度解析(何为ecmascript)
- 2025-05-05 Vite 性能篇:掌握这些优化策略,一起纵享丝滑!
- 2025-05-05 前端常见20道高频面试题深入解析(前端面试题目100及最佳答案)
- 2025-05-05 2025 年 Object 和 Map 如何选择?
- 2025-05-05 学习ES6- 入门Vue(大量源代码及笔记,带你起飞)
- 2025-05-05 AI 自我升级神操作,难道真要开启 “天网” 序章?
- 2025-05-05 JavaScript 数组去重方法总结(js 数组去重的四种方法)
- 2025-05-05 20 个让人惊叹的 JavaScript 单行代码技巧,效率瞬间提升
- 2025-05-05 ES6新特性面试题及答案(es6 面试)
- 10-02基于深度学习的铸件缺陷检测_如何控制和检测铸件缺陷?有缺陷铸件如何处置?
- 10-02Linux Mint 22.1 Cinnamon Edition 搭建深度学习环境
- 10-02AWD-LSTM语言模型是如何实现的_lstm语言模型
- 10-02NVIDIA Jetson Nano 2GB 系列文章(53):TAO模型训练工具简介
- 10-02使用ONNX和Torchscript加快推理速度的测试
- 10-02tensorflow GPU环境安装踩坑日记_tensorflow配置gpu环境
- 10-02Keye-VL-1.5-8B 快手 Keye-VL— 腾讯云两卡 32GB GPU保姆级部署指南
- 10-02Gateway_gateways
- 最近发表
-
- 基于深度学习的铸件缺陷检测_如何控制和检测铸件缺陷?有缺陷铸件如何处置?
- Linux Mint 22.1 Cinnamon Edition 搭建深度学习环境
- AWD-LSTM语言模型是如何实现的_lstm语言模型
- NVIDIA Jetson Nano 2GB 系列文章(53):TAO模型训练工具简介
- 使用ONNX和Torchscript加快推理速度的测试
- tensorflow GPU环境安装踩坑日记_tensorflow配置gpu环境
- Keye-VL-1.5-8B 快手 Keye-VL— 腾讯云两卡 32GB GPU保姆级部署指南
- Gateway_gateways
- Coze开源本地部署教程_开源canopen
- 扣子开源本地部署教程 丨Coze智能体小白喂饭级指南
- 标签列表
-
- cmd/c (90)
- c++中::是什么意思 (84)
- 标签用于 (71)
- 主键只能有一个吗 (77)
- c#console.writeline不显示 (95)
- pythoncase语句 (88)
- es6includes (74)
- sqlset (76)
- apt-getinstall-y (100)
- node_modules怎么生成 (87)
- chromepost (71)
- flexdirection (73)
- c++int转char (80)
- mysqlany_value (79)
- static函数和普通函数 (84)
- el-date-picker开始日期早于结束日期 (76)
- js判断是否是json字符串 (75)
- c语言min函数头文件 (77)
- asynccallback (87)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- java (73)
- js数组插入 (83)
- mac安装java (72)
- 无效的列索引 (74)