La méthode handler.getOwnPropertyDescriptor()
est une trappe pour intercepter Object.getOwnPropertyDescriptor()
.
Syntaxe
var p = new Proxy(cible, { getOwnPropertyDescriptor: function(cible, prop) { } });
Paramètres
Les paramètres suivants sont passés à la méthode getOwnPropertyDescriptor
. this
est ici lié au gestionnaire (handler).
cible
- L'objet cible
prop
- Le nom de la propriété dont on souhaite obtenir le descripteur.
Valeur de retour
La méthode getOwnPropertyDescriptor
doit renvoyer un objet ou undefined
.
Description
La méthode handler.getOwnPropertyDescriptor()
est une trappe pour un proxy afin d'intercepter les opérations effectuées avec Object.getOwnPropertyDescriptor()
.
Interceptions
Cette trappe permet d'intercepter :
Invariants
Si les invariants suivants ne sont pas respectés, le proxy lèvera une exception TypeError
:
getOwnPropertyDescriptor
doit renvoyer un objet ouundefined
.- Une propriété ne peut pas être indiquée comme non-existante s'il existe une propriété correspondante de l'objet cible qui est une propriété propre et non-configurable.
- Une propriété ne peut pas être indiquée comme non-existante s'il existe une propriété correspondante de l'objet cible qui est une propriété propre et que l'objet cible n'est pas extensible.
- Une propriété ne peut pas être indiquée comme existante si elle n'existe pas de façon correspondante sur l'objet cible et que l'objet cible n'est pas extensible.
- Une propriété ne peut pas être indiquée comme non-configurable si la propriété correspondante n'existe pas pour l'objet cible ou si elle existe comme un propriété propre configurable.
- Le résultat de
Object.getOwnPropertyDescriptor(cible)
peut être appliqué à l'objet cible avecObject.defineProperty
sans que cela lève une exception.
Exemples
Dans l'exemple qui suit, on intercepte Object.getOwnPropertyDescriptor()
.
var p = new Proxy({ a: 20 }, { getOwnPropertyDescriptor: function(cible, prop) { console.log("appelée : " + prop); return { configurable: true, enumerable: true, value: 10 }; } }); console.log(Object.getOwnPropertyDescriptor(p, "a").value); // "appelée : a" // 10
L'exemple suivant ne respecte pas un invariant :
var obj = { a: 10 }; Object.preventExtensions(obj); var p = new Proxy(obj, { getOwnPropertyDescriptor: function(cible, prop) { return undefined; } }); Object.getOwnPropertyDescriptor(p, "a"); // Une exception TypeError est renvoyée
Spécifications
Spécification | Statut | Commentaires |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) La définition de '[[GetOwnProperty]]' dans cette spécification. |
Standard | Définition initiale. |
ECMAScript 2016 Draft (7th Edition, ECMA-262) La définition de '[[GetOwnProperty]]' dans cette spécification. |
Projet |
Compatibilité des navigateurs
Fonctionnalité | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|
Support simple | ? | 18 (18) | ? | ? | ? |
Fonctionnalité | Android | Chrome pour Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Support simple | ? | ? | 18.0 (18) | ? | ? | ? |
Voir aussi
Étiquettes et contributeurs liés au document
Étiquettes :
Contributeurs à cette page :
SphinxKnight
Dernière mise à jour par :
SphinxKnight,