深度映射对象键

JavaScriptJavaScriptBeginner
立即练习

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

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

简介

在本实验中,我们将探索如何在 JavaScript 中使用 deepMapKeys 函数来递归地映射对象的键。我们将学习如何使用为每个键提供的函数创建一个具有相同值和映射键的新对象。通过实际操作练习和示例,我们将了解此函数的工作原理以及如何在实际场景中使用它。


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") subgraph Lab Skills javascript/variables -.-> lab-28265{{"深度映射对象键"}} javascript/data_types -.-> lab-28265{{"深度映射对象键"}} javascript/arith_ops -.-> lab-28265{{"深度映射对象键"}} javascript/comp_ops -.-> lab-28265{{"深度映射对象键"}} javascript/array_methods -.-> lab-28265{{"深度映射对象键"}} javascript/higher_funcs -.-> lab-28265{{"深度映射对象键"}} end

深度映射对象键

要深度映射对象的键,请执行以下步骤:

  1. 打开终端/SSH 并输入 node 开始练习编码。
  2. deepMapKeys 函数与提供的对象以及一个生成新键的函数一起使用。
  3. 该函数创建一个与提供的对象具有相同值的对象,其键是通过对每个键运行提供的函数生成的。
  4. 使用 Object.keys() 遍历对象的键。
  5. 使用 Array.prototype.reduce() 和提供的函数创建一个具有相同值和映射键的新对象。
  6. 如果值是一个对象,则对其递归调用 deepMapKeys 以映射其键。
const deepMapKeys = (obj, fn) =>
  Array.isArray(obj)
    ? obj.map((val) => deepMapKeys(val, fn))
    : typeof obj === "object"
      ? Object.keys(obj).reduce((acc, current) => {
          const key = fn(current);
          const val = obj[current];
          acc[key] =
            val !== null && typeof val === "object"
              ? deepMapKeys(val, fn)
              : val;
          return acc;
        }, {})
      : obj;

以下是 deepMapKeys 的一个示例用法:

const obj = {
  foo: "1",
  nested: {
    child: {
      withArray: [
        {
          grandChild: ["hello"]
        }
      ]
    }
  }
};

const upperKeysObj = deepMapKeys(obj, (key) => key.toUpperCase());
/*
{
  "FOO":"1",
  "NESTED":{
    "CHILD":{
      "WITHARRAY":[
        {
          "GRANDCHILD":[ 'hello' ]
        }
      ]
    }
  }
}
*/

总结

恭喜你!你已经完成了深度映射对象键实验。你可以在 LabEx 中练习更多实验来提升你的技能。