Сопоставить массив с объектом

Beginner

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

Введение

В этом практическом занятии мы изучим, как сопоставить массив объектов с объектом с использованием предоставленных функций сопоставления. Мы будем использовать метод Array.prototype.reduce(), чтобы сопоставить массив, а функции mapKey и mapValue — чтобы сопоставить ключи и значения результирующего объекта соответственно. В конце этого практического занятия вы будете лучше понимать, как преобразовывать структуры данных в JavaScript.

Как сопоставить массив с объектом в JavaScript

Чтобы сопоставить массив объектов с объектом в JavaScript, следуйте этим шагам:

  1. Откройте Терминал/SSH и введите node, чтобы начать практиковаться в написании кода.
  2. Используйте Array.prototype.reduce(), чтобы сопоставить массив с объектом.
  3. Используйте параметр mapKey, чтобы сопоставить ключи объекта, и параметр mapValue, чтобы сопоставить значения.

Вот пример кода, который демонстрирует, как использовать функцию objectify, чтобы сопоставить массив объектов с объектом:

const objectify = (arr, mapKey, mapValue = (i) => i) =>
  arr.reduce((acc, item) => {
    acc[mapKey(item)] = mapValue(item);
    return acc;
  }, {});

Затем вы можете использовать функцию objectify, чтобы сопоставить массив объектов с объектом следующими способами:

const people = [
  { name: "John", age: 42 },
  { name: "Adam", age: 39 }
];

// Сопоставьте массив объектов с объектом, используя свойство name в качестве ключей
objectify(people, (p) => p.name.toLowerCase());
// Вывод: { john: { name: 'John', age: 42 }, adam: { name: 'Adam', age: 39 } }

// Сопоставьте массив объектов с объектом, используя свойство name в качестве ключей и свойство age в качестве значений
objectify(
  people,
  (p) => p.name.toLowerCase(),
  (p) => p.age
);
// Вывод: { john: 42, adam: 39 }

Резюме

Поздравляем! Вы завершили практическое занятие по сопоставлению массива с объектом. Вы можете выполнить больше практических занятий в LabEx, чтобы улучшить свои навыки.