Proxy.revocable()

Метод Proxy.revocable() используется, чтобы создать отменяемый Proxy объект.

Синтаксис

Proxy.revocable(target, handler);

Параметры

Возвращаемое значение

Создаётся и возвращается отменяемый Proxy объект.

Описание

Отменяемый Proxy - объект со следующими двумя свойствами {proxy: proxy, revoke: revoke}.

proxy
Объект Proxy, созданный с помощью вызова new Proxy(target, handler).
revoke
Функция, не принимающая аргументов, которая сделает недействительным (выключит) proxy.

Если вызовется функция revoke(), proxy становится неиспользуемым: Любой proxy-перехватчик событий объекта будет вызывать исключение TypeError. Как только proxy отменена, она останется отменённой и дальше, и может быть собрана сборщиком мусора. Повторный вызов revoke() не будет иметь никакого эффекта.

Примеры

var revocable = Proxy.revocable({}, {
  get: function(target, name) {
    return "[[" + name + "]]";
  }
});
var proxy = revocable.proxy;
console.log(proxy.foo); // "[[foo]]"

revocable.revoke();

console.log(proxy.foo); // Вызвано исключение TypeError
proxy.foo = 1           // TypeError снова
delete proxy.foo;       // Всё ещё TypeError
typeof proxy            // "object", typeof не вызывает никаких proxy-перехватчиков событий

Спецификации

Specification Status Comment
ECMAScript 2015 (6th Edition, ECMA-262)
Определение 'Proxy Revocation Functions' в этой спецификации.
Стандарт Изначальное определение.
ECMAScript Latest Draft (ECMA-262)
Определение 'Proxy Revocation Functions' в этой спецификации.
Черновик  

Совместимость браузерами

Update compatibility data on GitHub
КомпьютерыМобильныеServer
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewChrome для AndroidFirefox для AndroidOpera для AndroidSafari on iOSSamsung InternetNode.js
revocableChrome Полная поддержка 63Edge Полная поддержка 12Firefox Полная поддержка 34IE Нет поддержки НетOpera Полная поддержка ДаSafari Полная поддержка 10WebView Android Полная поддержка 63Chrome Android Полная поддержка 63Firefox Android Полная поддержка 34Opera Android Полная поддержка ДаSafari iOS Полная поддержка 10Samsung Internet Android Полная поддержка 8.0nodejs Полная поддержка 6.0.0

Легенда

Полная поддержка  
Полная поддержка
Нет поддержки  
Нет поддержки

Смотрите также