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

View in English Always switch to English

handler.deleteProperty()

基线 广泛可用

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

handler.deleteProperty() 方法用于拦截对对象属性的 delete 操作。

语法

js
var p = new Proxy(target, {
  deleteProperty: function (target, property) {},
});

参数

deleteProperty 方法将会接受以下参数。this 被绑定在 handler 上。

target

目标对象。

property

待删除的属性名。

返回值

deleteProperty 必须返回一个 Boolean 类型的值,表示了该属性是否被成功删除。

描述

handler.deleteProperty() 方法可以拦截 delete 操作。

拦截

该方法会拦截以下操作:

不变量

如果违背了以下不变量,proxy 将会抛出一个 TypeError:

  • 如果目标对象的属性是不可配置的,那么该属性不能被删除。

示例

以下代码演示了对 delete 操作的拦截。

js
var p = new Proxy(
  {},
  {
    deleteProperty: function (target, prop) {
      console.log("called: " + prop);
      return true;
    },
  },
);

delete p.a; // "called: a"

规范

规范
ECMAScript® 2027 Language Specification
# sec-proxy-object-internal-methods-and-internal-slots-delete-p

浏览器兼容性

参见