Сумма элементов массива, полученных с использованием отображения

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

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

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

Введение

В этом лабе мы будем изучать концепцию суммы элементов массива, полученную с использованием отображения. Цель лабы - предоставить глубокое понимание того, как вычислить сумму элементов массива, отобразив каждый элемент на значение с использованием заданной функции. В конце этого лабы ученики смогут использовать Array.prototype.map() и 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-28486{{"Сумма элементов массива, полученных с использованием отображения"}} javascript/data_types -.-> lab-28486{{"Сумма элементов массива, полученных с использованием отображения"}} javascript/arith_ops -.-> lab-28486{{"Сумма элементов массива, полученных с использованием отображения"}} javascript/comp_ops -.-> lab-28486{{"Сумма элементов массива, полученных с использованием отображения"}} javascript/array_methods -.-> lab-28486{{"Сумма элементов массива, полученных с использованием отображения"}} javascript/higher_funcs -.-> lab-28486{{"Сумма элементов массива, полученных с использованием отображения"}} javascript/destr_assign -.-> lab-28486{{"Сумма элементов массива, полученных с использованием отображения"}} end

Функция для вычисления суммы элементов массива, полученных с использованием отображения

Для вычисления суммы элементов массива, отобразив каждого элемента на значение с использованием заданной функции, используйте функцию sumBy. Эта функция использует Array.prototype.map() для отображения каждого элемента на значение, возвращаемое fn. Затем она использует Array.prototype.reduce() для добавления каждого значения к накапливающемуся значению, которое инициализируется значением 0.

const sumBy = (arr, fn) =>
  arr
    .map(typeof fn === "function" ? fn : (val) => val[fn])
    .reduce((acc, val) => acc + val, 0);

Пример использования:

sumBy([{ n: 4 }, { n: 2 }, { n: 8 }, { n: 6 }], (x) => x.n); // Возвращает 20
sumBy([{ n: 4 }, { n: 2 }, { n: 8 }, { n: 6 }], "n"); // Возвращает 20

Для начала практики программирования с этой функцией откройте Терминал/SSH и введите node.

Резюме

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