--- title: Object.fromEntries() slug: Web/JavaScript/Reference/Global_Objects/Object/fromEntries tags: - JavaScript - Méthode - Object - Reference translation_of: Web/JavaScript/Reference/Global_Objects/Object/fromEntries original_slug: Web/JavaScript/Reference/Objets_globaux/Object/fromEntries ---
La méthode Object.fromEntries()
permet de transformer une liste de paires de clés/valeurs en un objet.
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 !
Object.fromEntries(iterable);
iterable
Un nouvel objet dont les propriétés sont fournies par les éléments de l'itérable.
La méthode Object.fromEntries()
prend comme argument une liste de paires de clés-valeurs et renvoie un nouvel objet dont les propriétés sont fournies par ces clés-valeurs. L'argument iterable
doit implémenter une méthode @@iterator
qui renvoie un itérateur produisant un objet semblable à un tableau avec deux éléments ; le premier élément est une valeur qui sera utilisée comme clé de la propriété et le second élément sera utilisé comme valeur associée à cette clé.
Object.fromEntries()
est la fonction inverse de {{jsxref("Object.entries()")}}.
Map
en un Object
Grâce à Object.fromEntries
, on peut convertir des objets {{jsxref("Map")}} en {{jsxref("Object")}} :
const map = new Map([ ['toto', 'truc'], ['machin', 42] ]); const obj = Object.fromEntries(map); console.log(obj); // { toto: "truc", machin: 42 }
Array
en un Object
Grâce à Object.fromEntries
, on peut convertir des objets {{jsxref("Array")}} en {{jsxref("Object")}} :
const arr = [ ['0', 'a'], ['1', 'b'], ['2', 'c'] ]; const obj = Object.fromEntries(arr); console.log(obj); // { 0: "a", 1: "b", 2: "c" }
Avec Object.fromEntries
et la méthode réciproque {{jsxref("Object.entries()")}}, et les méthodes de manipulation de tableaux, on peut transformer des objets :
const object1 = { a: 1, b: 2, c: 3 }; const object2 = Object.fromEntries( Object.entries(object1) .map(([ key, val ]) => [ key, val * 2 ]) ); console.log(object2); // { a: 2, b: 4, c: 6 }
Spécification | État | Commentaires |
---|---|---|
{{SpecName('ESDraft', '#sec-object.fromentries', 'Object.fromEntries')}} | {{Spec2('ESDraft')}} | Définition initiale avec ES2019. |
{{Compat("javascript.builtins.Object.fromEntries")}}