使用 JavaScript 转换对象属性

JavaScriptJavaScriptBeginner
立即练习

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

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

简介

在本实验中,我们将探索 JavaScript 中的 transform 函数,它允许我们对累加器和对象中的每个键应用指定的函数。通过使用 Object.keys()Array.prototype.reduce(),我们可以轻松地遍历对象中的每个键并执行所需的转换。本实验将提供使用这个实用函数的实践经验,并展示其在 JavaScript 编程中的实际应用。


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-28667{{"`使用 JavaScript 转换对象属性`"}} javascript/data_types -.-> lab-28667{{"`使用 JavaScript 转换对象属性`"}} javascript/arith_ops -.-> lab-28667{{"`使用 JavaScript 转换对象属性`"}} javascript/comp_ops -.-> lab-28667{{"`使用 JavaScript 转换对象属性`"}} javascript/array_methods -.-> lab-28667{{"`使用 JavaScript 转换对象属性`"}} javascript/higher_funcs -.-> lab-28667{{"`使用 JavaScript 转换对象属性`"}} javascript/destr_assign -.-> lab-28667{{"`使用 JavaScript 转换对象属性`"}} end

对象转换

要开始练习编码,请打开终端/SSH 并输入 node

transform 函数会从左到右对累加器和对象中的每个键应用指定的函数。以下是使用方法:

  • 使用 Object.keys() 遍历对象中的每个键。
  • 使用 Array.prototype.reduce() 对给定的累加器应用指定的函数。
const transform = (obj, fn, acc) =>
  Object.keys(obj).reduce((a, k) => fn(a, obj[k], k, obj), acc);

以下是一个示例:

transform(
  { a: 1, b: 2, c: 1 },
  (r, v, k) => {
    (r[v] || (r[v] = [])).push(k);
    return r;
  },
  {}
); // { '1': ['a', 'c'], '2': ['b'] }

总结

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

您可能感兴趣的其他 JavaScript 教程