--- title: Proxy.revocable() slug: Web/JavaScript/Reference/Global_Objects/Proxy/revocable tags: - ECMAScript6 - JavaScript - Method - Proxy translation_of: Web/JavaScript/Reference/Global_Objects/Proxy/revocable ---
Proxy.revocable()
方法可以用来创建一个可撤销的代理对象。
Proxy.revocable(target, handler);
target
Proxy
封装的目标对象。可以是任何类型的对象,包括原生数组,函数,甚至可以是另外一个代理对象。handler
返回一个包含了代理对象本身和它的撤销方法的可撤销 Proxy
对象。
该方法的返回值是一个对象,其结构为: {"proxy": proxy, "revoke": revoke}
,其中:
proxy
new Proxy(target, handler)
创建的代理对象没什么不同,只是它可以被撤销掉。revoke
一旦某个代理对象被撤销,它将变得几乎完全不可调用,在它身上执行任何的可代理操作都会抛出 {{jsxref("TypeError")}} 异常(注意,可代理操作一共有 {{jsxref("Proxy", "14 种", "#Methods_of_the_handler_object")}},执行这 14 种操作以外的操作不会抛出异常)。一旦被撤销,这个代理对象便不可能被直接恢复到原来的状态,同时和它关联的目标对象以及处理器对象都有可能被垃圾回收掉。再次调用撤销方法 revoke()
则不会有任何效果,但也不会报错。
var revocable = Proxy.revocable({}, { get(target, name) { return "[[" + name + "]]"; } }); var proxy = revocable.proxy; proxy.foo; // "[[foo]]" revocable.revoke(); console.log(proxy.foo); // 抛出 TypeError proxy.foo = 1 // 还是 TypeError delete proxy.foo; // 又是 TypeError typeof proxy // "object",因为 typeof 不属于可代理操作
规范名称 | 规范状态 | 备注 |
---|---|---|
{{SpecName('ES6', '#sec-proxy.revocable', 'Proxy Revocation Functions')}} | {{Spec2('ES6')}} |
{{Compat("javascript.builtins.Proxy.revocable")}}