Объединение отображенных массивов

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

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

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

Введение

В этом лабе мы будем изучать концепции программирования на JavaScript с помощью практических упражнений. Лаба предназначена для того, чтобы помочь участникам тщательно понять основные концепции JavaScript, такие как функции, массивы, объекты и циклы. С помощью серии вызовов и проектов участники получат возможность применить то, что они изучают, и укрепить свою уверенность как разработчиков на 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/AdvancedConceptsGroup -.-> javascript/higher_funcs("Higher-Order Functions") javascript/AdvancedConceptsGroup -.-> javascript/destr_assign("Destructuring Assignment") javascript/AdvancedConceptsGroup -.-> javascript/spread_rest("Spread and Rest Operators") subgraph Lab Skills javascript/variables -.-> lab-28488{{"Объединение отображенных массивов"}} javascript/data_types -.-> lab-28488{{"Объединение отображенных массивов"}} javascript/arith_ops -.-> lab-28488{{"Объединение отображенных массивов"}} javascript/comp_ops -.-> lab-28488{{"Объединение отображенных массивов"}} javascript/higher_funcs -.-> lab-28488{{"Объединение отображенных массивов"}} javascript/destr_assign -.-> lab-28488{{"Объединение отображенных массивов"}} javascript/spread_rest -.-> lab-28488{{"Объединение отображенных массивов"}} end

Функция для объединения массивов с использованием предоставленной функции сопоставления

Для начала кодирования откройте Терминал/SSH и введите node.

Эта функция возвращает массив элементов, которые присутствуют в одном из двух входных массивов, после применения предоставленной функции сопоставления к каждому элементу обоих массивов.

Вот шаги, чтобы достичь этого:

  1. Создайте новое Set, применяя функцию сопоставления ко всем значениям в первом входном массиве a.
  2. Создайте еще одно Set, состоящее из всех элементов в b, которые не совпадают с любыми значениями в ранее созданном Set, когда функция сопоставления применяется.
  3. Объедините два множества и преобразуйте их в массив.
  4. Верните полученный массив.

Вот код для функции unionBy:

const unionBy = (a, b, fn) => {
  const setA = new Set(a.map(fn));
  return Array.from(new Set([...a, ...b.filter((x) => !setA.has(fn(x)))]));
};

Вот некоторые примеры использования функции unionBy:

unionBy([2.1], [1.2, 2.3], Math.floor); // Output: [2.1, 1.2]
unionBy([{ id: 1 }, { id: 2 }], [{ id: 2 }, { id: 3 }], (x) => x.id);
// Output: [{ id: 1 }, { id: 2 }, { id: 3 }]

Резюме

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