--- title: Reflect slug: Web/JavaScript/Reference/Global_Objects/Reflect tags: - ECMAScript 2015 - JavaScript - Reference - Reflect translation_of: Web/JavaScript/Reference/Global_Objects/Reflect original_slug: Web/JavaScript/Reference/Objets_globaux/Reflect ---
{{JSRef}}

Reflect est un objet natif qui fournit des méthodes pour les opérations qui peuvent être interceptées en JavaScript (via les proxies). Les méthodes de cet objet sont les mêmes que celles des gestionnaires de proxy. Reflect n'est pas une fonction (y compris pour construire un objet).

Description

Contrairement à la plupart des objets globaux, Reflect n'est pas un constructeur. Il ne peut pas être utilisé avec l'opérateur {{jsxref("Opérateurs/L_opérateur_new","new")}} ou être invoqué comme une fonction. Les propriétés et méthodes de Reflect sont statiques (comme pour celles de l'objet {{jsxref("Math")}}).

Méthodes

L'objet Reflect fournit des fonctions statiques qui ont les mêmes noms que les méthodes des gestionnaires de proxy et dont certaines correspondent, avec quelques différences, à celles d'{{jsxref("Object")}} :

{{jsxref("Reflect.apply()")}}
Appelle une fonction cible avec les arguments définis par le paramètres args. Voir aussi {{jsxref("Function.prototype.apply()")}}.
{{jsxref("Reflect.construct()")}}
 L'opérateur {{jsxref("Opérateurs/L_opérateur_new","new")}} comme fonction. C'est équivalent à new cible(...args). Cette méthode permet également d'indiquer un prototype différent.
{{jsxref("Reflect.defineProperty()")}}
Semblable à {{jsxref("Object.defineProperty()")}}. Renvoie un {{jsxref("Boolean")}}.
{{jsxref("Reflect.deleteProperty()")}}
L'opérateur {{jsxref("Opérateurs/L_opérateur_delete","delete")}} comme fonction. C'est équivalent à delete cible[nom].
{{jsxref("Reflect.get()")}}
Une fonction qui renvoie la valeur d'une propriété.
{{jsxref("Reflect.getOwnPropertyDescriptor()")}}
Semblable à {{jsxref("Object.getOwnPropertyDescriptor()")}}. Renvoie un descripteur de propriété si la propriété existe sur l'objet, {{jsxref("undefined")}} sinon.
{{jsxref("Reflect.getPrototypeOf()")}}
Identique à {{jsxref("Object.getPrototypeOf()")}}.
{{jsxref("Reflect.has()")}}
L'opérateur {{jsxref("Opérateurs/L_opérateur_in","in")}} comme fonction. Renvoie un booléen qui indique si une telle propriété existe pour l'objet (qu'elle soit directement rattachée ou héritée).
{{jsxref("Reflect.isExtensible()")}}
La même fonction que {{jsxref("Object.isExtensible()")}}.
{{jsxref("Reflect.ownKeys()")}}
Renvoie un tableau de chaînes de caractères qui correspondent aux noms des propriétés propres (celles qui ne sont pas héritées) de l'objet.
{{jsxref("Reflect.preventExtensions()")}}
Semblable à {{jsxref("Object.preventExtensions()")}}. Renvoie un {{jsxref("Boolean")}}.
{{jsxref("Reflect.set()")}}
Une fonction qui affecte des valeurs à des propriétés. Renvoie un {{jsxref("Boolean")}} qui vaut true si la mise à jour a bien été effectuée.
{{jsxref("Reflect.setPrototypeOf()")}}
Une fonction qui permet de définir le prototype d'un objet.

Spécifications

Spécification État Commentaires
{{SpecName('ES2015', '#sec-reflect-object', 'Reflect')}} {{Spec2('ES2015')}} Définition initiale.
{{SpecName('ESDraft', '#sec-reflect-object', 'Reflect')}} {{Spec2('ESDraft')}} Retrait de Reflect.enumerate

Compatibilité des navigateurs

{{Compat("javascript.builtins.Reflect")}}

Voir aussi