Reflect.isExtensible()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.
La méthode statique Reflect.isExtensible()
permet de déterminer si un objet est extensible (i.e. si on peut lui ajouter de nouvelles propriétés). Elle est semblable à la méthode Object.isExtensible()
(modulo quelques différences).
Exemple interactif
Syntaxe
Reflect.isExtensible(cible);
Paramètres
cible
-
L'objet cible dont on souhaite savoir s'il est extensible.
Valeur de retour
Un booléen qui indique si la cible est extensible ou non.
Exceptions
Description
La méthode Reflect.isExtensible
permet de déterminer si un objet est extensible (autrement dit si on peut lui ajouter de nouvelles propriétés). Cette méthode est semblable à la méthode Object.isExtensible()
.
Exemples
Utiliser Reflect.isExtensible()
Voir aussi Object.isExtensible()
.
// Les nouveaux objets sont extensibles.
var vide = {};
Reflect.isExtensible(vide); // true
// ...mais ça peut être changé.
Reflect.preventExtensions(vide);
Reflect.isExtensible(vide); // false
// Par définition, les objets scellés
// ne sont pas extensibles.
var scellé = Object.seal({});
Reflect.isExtensible(scellé); // false
// Par définition, les objets gelés sont
// également non-extensibles.
var gelé = Object.freeze({});
Reflect.isExtensible(gelé); // false
Différence avec Object.isExtensible()
Si le premier argument passé à la méthode n'est pas un objet (autrement dit si la valeur est une valeur primitive), cela provoquera une exception TypeError
. La méthode Object.isExtensible()
aurait commencé par convertir l'argument en un objet.
Reflect.isExtensible(1);
// TypeError: 1 is not an object
Object.isExtensible(1);
// false
Spécifications
Specification |
---|
ECMAScript Language Specification # sec-reflect.isextensible |
Compatibilité des navigateurs
BCD tables only load in the browser