Преобразование свойств объекта с использованием JavaScript

JavaScriptJavaScriptBeginner
Практиковаться сейчас

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

💡 Этот учебник переведен с английского с помощью ИИ. Чтобы просмотреть оригинал, вы можете перейти на английский оригинал

Введение

В этом практическом занятии мы изучим функцию transform в JavaScript, которая позволяет применить указанную функцию к аккумулятору и каждому ключу объекта. Используя 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, чтобы улучшить свои навыки.