网站首页 > 知识剖析 正文
数组去重在前端开发中非常有用,在很多业务场景中都有需要。我们都知道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 或者数组的其他方法都可以。
关于数组去重你还有什么方法,欢迎留言分享~
欢迎点赞,评论,转发 ~
- 上一篇: JavaScript奇淫技巧:利用数组加密并压缩代码
- 下一篇:已经是最后一篇了
猜你喜欢
- 2025-09-01 JavaScript奇淫技巧:利用数组加密并压缩代码
- 2025-09-01 七爪源码:修复 JavaScript 错误的 4 种方法
- 2025-09-01 我是如何使用ChatGPT和CoPilot作为编码助手的
- 2025-09-01 12种JavaScript中最常用的数组操作整理汇总
- 2025-09-01 深入JavaScript教你内存泄漏如何防范
- 2025-09-01 Javascript中的字符串拼接_javascript 字符串拼接
- 2025-09-01 JavaScript 合并数组的三种方法_javascript合并对象
- 2025-09-01 js中数组filter方法的使用和实现_js数组 filter
- 2025-09-01 使用js把某个乱序的数组变成升序序或者降序的数组的方法
- 2025-09-01 PHP设计模式之组合模式_php几种设计模式
- 最近发表
- 标签列表
-
- xml (46)
- css animation (57)
- array_slice (60)
- htmlspecialchars (54)
- position: absolute (54)
- datediff函数 (47)
- array_pop (49)
- jsmap (52)
- toggleclass (43)
- console.time (63)
- .sql (41)
- ahref (40)
- js json.parse (59)
- html复选框 (60)
- css 透明 (44)
- css 颜色 (47)
- php replace (41)
- css nth-child (48)
- min-height (40)
- xml schema (44)
- css 最后一个元素 (46)
- location.origin (44)
- table border (49)
- html tr (40)
- video controls (49)