登录
首页 >  文章 >  前端

JavaScriptSet用法及去重技巧

时间:2026-01-07 15:42:41 217浏览 收藏

怎么入门文章编程?需要学习哪些知识点?这是新手们刚接触编程时常见的问题;下面golang学习网就来给大家整理分享一些知识点,希望能够给初学者一些帮助。本篇文章就来介绍《JavaScript中Set的用法及存储唯一值方法》,涉及到,有需要的可以收藏一下

JavaScript Set 是用于存储唯一值的内置对象,自动去重、支持高效存在性判断与集合运算,不按索引排序,可通过 add/has/delete/clear 等方法操作,支持 for...of 和 forEach 遍历及转数组等转换。

javascript Set是什么_怎样用它存储唯一值的集合?

JavaScript Set 是一个内置对象,用来存储唯一值的集合,无论值的类型是原始类型还是对象,重复添加的值都会被自动忽略。 它不按索引排序,也不支持通过下标访问元素,但能高效地判断某个值是否存在、去重、求交集或差集等。

创建和初始化 Set

new Set() 创建空集合,也可以传入一个可迭代对象(如数组)来初始化:

  • const set1 = new Set(); —— 创建空 Set
  • const set2 = new Set([1, 2, 2, 3, 3]); —— 自动去重,结果为 {1, 2, 3}
  • const set3 = new Set("hello"); —— 字符串会被拆成单字符,结果为 {"h", "e", "l", "o"}(注意:只有一个 "l")

常用操作方法

Set 提供了清晰的方法管理数据:

  • add(value):添加一个值,返回 Set 本身(可链式调用)
  • has(value):返回布尔值,判断是否包含某值(比数组 includes 更快,尤其大数据量)
  • delete(value):删除指定值,返回是否删除成功
  • clear():清空所有元素
  • size:获取当前元素个数(不是方法,是属性)

例如:
const colors = new Set();
colors.add("red").add("blue").add("red"); // 只存两个值
console.log(colors.size); // 2
console.log(colors.has("green")); // false

遍历和转换

Set 支持多种遍历方式,也容易转成其他数据结构:

  • for...of 循环:for (const color of colors) { console.log(color); }
  • forEachcolors.forEach(c => console.log(c));
  • 转为数组:[...colors]Array.from(colors)
  • 转为字符串(需手动处理):Array.from(colors).join(", ")

配合数组去重和集合运算

Set 最常见的用途之一就是快速去重:

  • 数组去重:[...new Set([1, 2, 2, 3])] → [1, 2, 3]
  • 求并集:new Set([...setA, ...setB])
  • 求交集:new Set([...setA].filter(x => setB.has(x)))
  • 求差集(A 减 B):new Set([...setA].filter(x => !setB.has(x)))

注意:Set 的相等判断使用 SameValueZero 算法,所以 NaN === NaN 为 true,0-0 被视为相同。

到这里,我们也就讲完了《JavaScriptSet用法及去重技巧》的内容了。个人认为,基础知识的学习和巩固,是为了更好的将其运用到项目中,欢迎关注golang学习网公众号,带你了解更多关于的知识点!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>