Baseline Widely available
La méthode Proxy.revocable()
est utilisée afin de créer un objet Proxy
révocable.
Proxy.revocable(cible, gestionnaire);
Paramètres
cible
Un objet cible devant lequel on veut placer un intermédiaire. Ãa peut être n'importe quelle sorte d'objet : un tableau, une fonction, voire un autre proxy.
gestionnaire
Un objet dont les propriétés sont des fonctions qui définissent les opérations interceptées par le proxy par rapport à l'objet cible.
Un nouvel objet Proxy
révocable est renvoyé par la méthode.
Un Proxy
révocable est un objet qui possède les propriétés suivantes : {proxy: proxy, revoke: revoke}
.
proxy
Un proxy créé avec un appel à new Proxy(cible, gestionnaire)
.
revoke
Une fonction sans argument qui permet de désactiver le proxy.
Si la fonction revoke()
est appelée, le proxy devient inutilisable et toutes les trappes définies via un gestionnaire lèveront une exception TypeError
. Une fois que le proxy est révoqué, il conserve cet état et peut être traité par le ramasse-miettes. D'éventuels appels suivants à revoke()
n'auront aucun effet.
Proxy.revocable()
let revocable = Proxy.revocable(
{},
{
get: function (cible, nom) {
return "[[" + nom + "]]";
},
},
);
let proxy = revocable.proxy;
console.log(proxy.toto); // "[[toto]]"
revocable.revoke();
console.log(proxy.toto); // TypeError est levée
proxy.toto = 1; // TypeError à nouveau
delete proxy.toto; // TypeError toujours
typeof proxy; // "object", typeof ne déclenche aucune trappe
Spécifications Compatibilité des navigateurs Voir aussi
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4