--- title: Reflect.deleteProperty() slug: Web/JavaScript/Reference/Global_Objects/Reflect/deleteProperty tags: - ECMAScript 2015 - JavaScript - Méthode - Reference - Reflect translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/deleteProperty original_slug: Web/JavaScript/Reference/Objets_globaux/Reflect/deleteProperty ---
La méthode statique Reflect.deleteProperty() permet de supprimer des propriétés. Il agit comme l'opérateur delete.
Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner https://github.com/mdn/interactive-examples et à envoyer une pull request !
Reflect.deleteProperty(cible, cléPropriété)
ciblecléPropriétéUn {{jsxref("Boolean","booléen","",1)}} qui indique si la suppression de la propriété s'est bien passée.
Une erreur {{jsxref("TypeError")}} si cible n'est pas un {{jsxref("Object")}}.
La méthode Reflect.deleteProperty permet de supprimer une propriété d'un objet. Elle renvoie un {{jsxref("Boolean")}} qui indique si la propriété a été supprimée correctement. Cette méthode est très proche de l'opérateur delete.
var obj = { x: 1, y: 2 };
Reflect.deleteProperty(obj, "x"); // true
obj; // { y: 2 }
var arr = [1, 2, 3, 4, 5];
Reflect.deleteProperty(arr, "3"); // true
arr; // [1, 2, 3, , 5]
// Renvoie true si aucune propriété correspondante n'existe
Reflect.deleteProperty({}, "toto"); // true
// Renvoie false si une propriété n'est pas configurable
Reflect.deleteProperty(Object.freeze({toto: 1}),"toto"); // false
| Spécification | État | Commentaires |
|---|---|---|
| {{SpecName('ES2015', '#sec-reflect.deleteproperty', 'Reflect.deleteProperty')}} | {{Spec2('ES2015')}} | Définition initiale. |
| {{SpecName('ESDraft', '#sec-reflect.deleteproperty', 'Reflect.deleteProperty')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.Reflect.deleteProperty")}}
delete