Inverser les paires clé-valeur d'un objet

JavaScriptJavaScriptBeginner
Pratiquer maintenant

This tutorial is from open-source community. Access the source code

💡 Ce tutoriel est traduit par l'IA à partir de la version anglaise. Pour voir la version originale, vous pouvez cliquer ici

Introduction

Dans ce laboratoire, nous allons explorer la manière d'inverser les paires clé-valeur d'un objet sans modifier l'objet original. Nous utiliserons la méthode Object.keys() et Array.prototype.reduce() pour inverser l'objet. De plus, nous apprendrons à appliquer une fonction aux clés inversées et à retourner un tableau de clés responsables de la génération de la valeur inversée.


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("JavaScript")) -.-> javascript/BasicConceptsGroup(["Basic Concepts"]) javascript(("JavaScript")) -.-> javascript/AdvancedConceptsGroup(["Advanced Concepts"]) javascript/BasicConceptsGroup -.-> javascript/variables("Variables") javascript/BasicConceptsGroup -.-> javascript/data_types("Data Types") javascript/BasicConceptsGroup -.-> javascript/arith_ops("Arithmetic Operators") javascript/BasicConceptsGroup -.-> javascript/comp_ops("Comparison Operators") javascript/BasicConceptsGroup -.-> javascript/array_methods("Array Methods") javascript/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") subgraph Lab Skills javascript/variables -.-> lab-28404{{"Inverser les paires clé-valeur d'un objet"}} javascript/data_types -.-> lab-28404{{"Inverser les paires clé-valeur d'un objet"}} javascript/arith_ops -.-> lab-28404{{"Inverser les paires clé-valeur d'un objet"}} javascript/comp_ops -.-> lab-28404{{"Inverser les paires clé-valeur d'un objet"}} javascript/array_methods -.-> lab-28404{{"Inverser les paires clé-valeur d'un objet"}} javascript/higher_funcs -.-> lab-28404{{"Inverser les paires clé-valeur d'un objet"}} javascript/destr_assign -.-> lab-28404{{"Inverser les paires clé-valeur d'un objet"}} end

Fonction pour inverser un objet

Pour inverser les paires clé-valeur d'un objet sans modifier l'objet original, utilisez la fonction invertKeyValues.

  • Appelez la fonction en tapant invertKeyValues(obj, fn) dans le Terminal/SSH, où obj est l'objet à inverser et fn est une fonction optionnelle à appliquer à la clé inversée.

  • Les méthodes Object.keys() et Array.prototype.reduce() sont utilisées pour créer un nouvel objet avec des paires clé-valeur inversées, et si une fonction est fournie, elle est appliquée à chaque clé inversée.

  • Si fn est omise, la fonction renvoie seulement les clés inversées sans aucune fonction appliquée à elles.

  • La fonction renvoie un objet avec chaque valeur inversée étant un tableau de clés responsables de la génération de la valeur inversée.

const invertKeyValues = (obj, fn) =>
  Object.keys(obj).reduce((acc, key) => {
    const val = fn ? fn(obj[key]) : obj[key];
    acc[val] = acc[val] || [];
    acc[val].push(key);
    return acc;
  }, {});

Utilisation de l'exemple :

invertKeyValues({ a: 1, b: 2, c: 1 }); // { 1: [ 'a', 'c' ], 2: [ 'b' ] }
invertKeyValues({ a: 1, b: 2, c: 1 }, (value) => "group" + value);
// { group1: [ 'a', 'c' ], group2: [ 'b' ] }

Résumé

Félicitations ! Vous avez terminé le laboratoire Invert Object. Vous pouvez pratiquer d'autres laboratoires dans LabEx pour améliorer vos compétences.