此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。
WeakSet
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since 2015年9月.
* Some parts of this feature may have varying levels of support.
WeakSet 是可被垃圾回收的值的集合,包括对象和非全局注册的符号。WeakSet 中的值只能出现一次。它在WeakSet 的集合中是唯一的。
In this article
描述
WeakSet 中的值一定是可被垃圾回收的值。大多数原始数据类型可以被任意地创建,并且没有生命周期,所以它们不能被存储。对象和非全局注册的符号可以被存储,因为它们是可被垃圾回收的值。
它和Set 对象的主要区别有:
WeakSet只能是对象和符号的集合,它不能像Set那样包含任何类型的任意值。WeakSet持弱引用:WeakSet中对象的引用为弱引用。如果没有其他的对WeakSet中对象的引用存在,那么这些对象会被垃圾回收。备注:这也意味着集合中没有存储当前值的列表。
WeakSet是不可枚举的。
用例:检测循环引用
递归调用自身的函数需要一种通过跟踪哪些对象已被处理,来应对循环数据结构的方法。
为此,WeakSet 非常适合处理这种情况:
// 对传入的 subject 对象内部存储的所有内容执行回调function execRecursively(fn, subject, _refs = new WeakSet()) { // 避免无限递归 if (_refs.has(subject)) { return; } fn(subject); if (typeof subject === "object") { _refs.add(subject); for (const key in subject) { execRecursively(fn, subject[key], _refs); } }}const foo = { foo: "Foo", bar: { bar: "Bar", },};foo.bar.baz = foo; // 循环引用!execRecursively((obj) => console.log(obj), foo);在此,在第一次运行时创建WeakSet,并将其与每个后续函数调用一起传递(使用内部参数_refs)。
对象的数量或它们的遍历顺序无关紧要,因此,WeakSet 比Set 更适合(和执行)跟踪对象引用,尤其是在涉及大量对象时。
构造函数
WeakSet()创建一个新的
WeakSet对象。
实例属性
这些属性在WeakSet.prototype 上定义,并且由所有WeakSet 实例所共享。
WeakSet.prototype.constructor创建了该实例对象的构造函数。对于
WeakSet实例,初始值是WeakSet构造函数。WeakSet.prototype[Symbol.toStringTag][Symbol.toStringTag]属性的初始值是字符串"WeakSet"。该属性被Object.prototype.toString()所使用。
实例方法
WeakSet.prototype.add()将
value追加到WeakSet对象。WeakSet.prototype.delete()从
WeakSet中移除value。此后调用WeakSet.prototype.has(value)将返回false。WeakSet.prototype.has()返回一个表示
value是否存在于WeakSet对象中的布尔值。
示例
>使用 WeakSet 对象
const ws = new WeakSet();const foo = {};const bar = {};ws.add(foo);ws.add(bar);ws.has(foo); // truews.has(bar); // truews.delete(foo); // 从 set 中删除 foo 对象ws.has(foo); // false,foo 对象已经被删除了ws.has(bar); // true,bar 依然存在注意,foo !== bar。尽管它们是相似的对象,但是它们不是同一个对象。因此,它们都可以被加入到集合中。
规范
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-weakset-objects> |