反转对象键值对

JavaScriptJavaScriptBeginner
立即练习

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

💡 本教程由 AI 辅助翻译自英文原版。如需查看原文,您可以 切换至英文原版

简介

在这个实验中,我们将探索如何在不改变原始对象的情况下反转对象的键值对。我们将使用 Object.keys() 方法和 Array.prototype.reduce() 来反转对象。此外,我们将学习如何将一个函数应用于反转后的键,并返回负责生成反转后值的键的数组。


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{{"反转对象键值对"}} javascript/data_types -.-> lab-28404{{"反转对象键值对"}} javascript/arith_ops -.-> lab-28404{{"反转对象键值对"}} javascript/comp_ops -.-> lab-28404{{"反转对象键值对"}} javascript/array_methods -.-> lab-28404{{"反转对象键值对"}} javascript/higher_funcs -.-> lab-28404{{"反转对象键值对"}} javascript/destr_assign -.-> lab-28404{{"反转对象键值对"}} end

反转对象的函数

要在不改变原始对象的情况下反转对象的键值对,请使用 invertKeyValues 函数。

  • 在终端/SSH 中输入 invertKeyValues(obj, fn) 来调用该函数,其中 obj 是要反转的对象,fn 是一个可选函数,将应用于反转后的键。

  • Object.keys()Array.prototype.reduce() 方法用于创建一个具有反转键值对的新对象,如果提供了函数,则将其应用于每个反转后的键。

  • 如果省略 fn,则函数仅返回反转后的键,而不对其应用任何函数。

  • 该函数返回一个对象,其中每个反转后的值都是负责生成该反转后值的键的数组。

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;
  }, {});

示例用法:

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' ] }

总结

恭喜你!你已经完成了“反转对象”实验。你可以在 LabEx 中练习更多实验来提升你的技能。