此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。

View in English Always switch to English

WeakSet.prototype.delete()

基线 广泛可用

自 2015年9月 起,此特性已在主流浏览器中得到支持,可在大多数设备和浏览器版本中正常使用。

WeakSet 实例的 delete() 方法从该 WeakSet 对象中删除指定的元素。

尝试一下

const weakset1 = new WeakSet();
const object1 = {};

weakset1.add(object1);

console.log(weakset1.has(object1));
// Expected output: true

weakset1.delete(object1);

console.log(weakset1.has(object1));
// Expected output: false

语法

js
weakSetInstance.delete(value)

参数

value

要从 WeakSet 对象中删除的值。

返回值

如果成功在 WeakSet 对象中删除了元素,则返回 true。如果未在 WeakSet 中找到该 value,则返回 false。如果 value 不是对象或非全局注册的符号,则始终返回 false

示例

使用 delete() 方法

js
const ws = new WeakSet();
const obj = {};

ws.add(window);

ws.delete(obj); // 返回 false。没有找到要删除的对象。
ws.delete(window); // 返回 true。成功删除。

ws.has(window); // 返回 false。WeakMap 中已经不存在 window 对象。

规范

规范
ECMAScript® 2027 Language Specification
# sec-weakset.prototype.delete

浏览器兼容性

参见