Le symbole « connu » Symbol.toPrimitive
définit une fonction qui est appelée pour convertir un objet en une valeur primitive.
The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.
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 !
Description
Lorsqu'on convertit un objet en une valeur primitive et que l'objet possède une propriété Symbol.toPrimitive
dont la valeur est une fonction, la fonction est appelée avec une chaîne de caractère (hint
) qui définit le type qu'on privilégie pour la valeur primitive. L'argument hint
peut prendre l'une des valeurs suivantes : "number"
, "string"
ou "default"
.
Attributs de Symbol.toPrimitive |
|
---|---|
Écrivable | Non |
Énumérable | Non |
Configurable | Non |
Exemples
Dans l'exemple qui suit, on voit comment la propriété Symbol.toPrimitive
peut modifier la valeur primitive obtenue lors de la conversion d'un objet.
// Premier cas avec un objet sans Symbol.toPrimitive.
let obj1 = {};
console.log(+obj1); // NaN
console.log(`${obj1}`); // "[object Object]"
console.log(obj1 + ""); // "[object Object]"
// Second cas : l'objet a une propriété Symbol.toPrimitive
var obj2 = {
[Symbol.toPrimitive](hint) {
if (hint === "number") {
return 10;
}
if (hint === "string") {
return "coucou";
}
return true;
}
};
console.log(+obj2); // 10 -- hint vaut "number"
console.log(`${obj2}`); // "coucou" -- hint vaut "string"
console.log(obj2 + ""); // true -- hint vaut "default"
Spécifications
Spécification | Etat | Commentaires |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) La définition de 'Symbol.toPrimitive' dans cette spécification. |
Standard | Définition initiale. |
ECMAScript (ECMA-262) La définition de 'Symbol.toPrimitive' dans cette spécification. |
Standard évolutif |
Compatibilité des navigateurs
BCD tables only load in the browser