Object
Baseline Widely available *
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
* Some parts of this feature may have varying levels of support.
Le type Object
est l'un des types de données JavaScript. Il est utilisé pour stocker des ensembles de clés/valeurs et des entités plus complexes. Les objets peuvent être créés avec le constructeur Object()
ou avec la syntaxe d'initialisation d'objet littérale.
Description
La quasi-totalité des objets en JavaScript sont des instances d'Object
. En général, un objet hérite de propriétés (dont des méthodes) de Object.prototype
, bien que ces propriétés puissent être surchargées. Il sera toutefois possible de créer un Object
qui n'obéit pas à ces règles (par exemple en utilisant Object.create(null)
ou de modifier un objet après sa construction afin que ces hypothèses ne soient plus vérifiées (par exemple avec Object.setPrototypeOf()
).
Les modifications apportées à l'objet prototype de Object
seront captées par tous les objets à travers le chaînage des prototypes, à moins que ces propriétés soient surchargées plus bas sur la chaîne des prototypes. C'est donc un moyen puissant mais également dangereux permettant de modifier le comportement des objets.
Le constructeur Object
crée une enveloppe objet de la valeur passée en argument.
- Si la valeur est
null
ouundefined
, il créera et renverra un objet vide. - Si la valeur est déjà un objet, il renverra la valeur.
- Sinon, il renverra un objet dont le type objet correspond au type primitif de la valeur fournie.
Lorsqu'il n'est pas appelé dans un contexte constructeur (c'est-à-dire sans le mot-clé new
), Object
se comporte de façon identique à new Object()
.
Voir aussi initialisateur d'objet / syntaxe de littéral.
Supprimer une propriété d'un objet
Il n'existe pas de méthode pour Object
qui permette de supprimer une propriété propre (à l'instar de Map.prototype.delete()
). Pour ce faire, il faut utiliser l'opérateur delete
.
Constructeur
Object()
-
Crée un nouvel objet
Object
à partir de la valeur fournie.
Méthodes du constructeur Object
Object.assign()
-
Copie les valeurs de toutes les propriétés propres énumérables depuis un ou plusieurs objets source dans un objet cible.
Object.create()
-
Crée un nouvel objet avec le prototype d'objet et les propriétés indiqués.
Object.defineProperty()
-
Ajoute à un objet la propriété nommée décrite par le descripteur donné.
Object.defineProperties()
-
Ajoute à un objet les propriétés nommées décrites par les descripteurs donnés.
Object.entries()
-
Retourne un tableau contenant les paires
[clé, valeur]
des propriétés énumérables propres (c'est-à-dire directement rattachées à l'objet) de l'objet donné et dont les clés sont des chaînes de caractères. Object.freeze()
-
Gèle un objet : un autre code ne peut ni détruire ni changer aucune propriété.
Object.fromEntries()
-
Renvoie un nouvel objet à partir d'un itérable contenant des paires de clés-valeurs (l'opération duale de
Object.entries()
). Object.getOwnPropertyDescriptor()
-
Retourne un descripteur de propriété pour une propriété nommée d'un objet.
Object.getOwnPropertyDescriptors()
-
Retourne un objet contenant tous les descripteurs des propriétés propres d'un objet.
Object.getOwnPropertyNames()
-
Retourne un tableau contenant les noms de toutes les propriétés énumérables et non énumérables propres de l'objet donné.
Object.getOwnPropertySymbols()
-
Retourne un tableau de toutes les propriétés symboles trouvées directement dans un objet donné.
Object.getPrototypeOf()
-
Retourne le prototype de l'objet indiqué.
Object.is()
-
Détermine si deux valeurs sont la même valeur. Considère comme égales toutes les valeurs NaN (ce qui diffère à la fois de la comparaison d'égalité abstraite et de la comparaison d'égalité stricte).
Object.isExtensible()
-
Détermine si l'extension d'un objet est permise.
Object.isFrozen()
-
Détermine si un objet a été gelé.
Object.isSealed()
-
Détermine si un objet est scellé.
Object.keys()
-
Retourne un tableau contenant les noms de toutes les propriétés énumérables propres de l'objet donné.
Object.preventExtensions()
-
Empêche toute extension de l'objet.
Object.seal()
-
Empêche un autre code de détruire les propriétés d'un objet.
Object.setPrototypeOf()
-
Définit le prototype d'un objet (c'est-à-dire, la propriété interne
[[Prototype]]
). Object.values()
-
Retourne le tableau des valeurs énumérables propres de l'objet donné dont les clés sont des chaînes de caractères.
Propriétés des instances
Object.prototype.constructor
-
Définit la fonction qui crée le prototype d'un objet.
Object.prototype.__proto__
-
Pointe vers l'objet ayant été utilisé comme prototype à l'instanciation de l'objet.
Méthodes des instances
Object.prototype.__defineGetter__()
-
Associe une fonction à une propriété, lorsqu'on accède à cette dernière, la fonction est exécutée et la valeur de retour est renvoyée.
Object.prototype.__defineSetter__()
-
Associe une fonction à une propriété, lorsqu'on modifie cette dernière, la fonction est exécutée pour modifier la propriété.
Object.prototype.__lookupGetter__()
-
Renvoie la fonction qui a été associée à la propriété indiquée avec la méthode
__defineGetter__()
. Object.prototype.__lookupSetter__()
-
Renvoie la fonction qui a été associée à la propriété indiquée avec la méthode
__defineSetter__()
. Object.prototype.hasOwnProperty()
-
Renvoie un booléen indiquant si un objet contient la propriété indiquée comme une propriété propre (directement rattachée à l'objet, pas héritée avec sa chaîne de prototypes).
Object.prototype.isPrototypeOf()
-
Renvoie un booléen indiquant si l'objet courant (pour lequel est appelé cette méthode) fait partie de la chaîne de prototypes de l'objet passé en argument.
Object.prototype.propertyIsEnumerable()
-
Renvoie un booléen indiquant si l'attribut interne ECMAScript
[[Enumerable]]
est fixé. Object.prototype.toLocaleString()
-
Appelle la méthode
toString()
. Object.prototype.toString()
-
Renvoie une chaîne de caractères qui représente l'objet.
Object.prototype.valueOf()
-
Renvoie la valeur primitive de l'objet indiqué.
Exemples
Utilisation d'Object
avec les types undefined
et null
Les exemples suivants stockent un Object
vide dans o
:
let o = new Object();
let o = new Object(undefined);
let o = new Object(null);
Utilisation d'Object
pour créer des objets Boolean
Les exemples suivants stockent des objets Boolean
dans o
:
// Équivalent à : o = new Boolean(true);
let o = new Object(true);
// Équivalent à : o = new Boolean(false);
let o = new Object(Boolean());
Spécifications
Specification |
---|
ECMAScript Language Specification # sec-object-objects |
Compatibilité des navigateurs
BCD tables only load in the browser