Предположим, вы находитесь в процессе выполнения сложного проекта по веб-разработке. К вам поступают данные из множества API, и надо эффективно их обрабатывать, фильтровать и анализировать. Вы работаете в напряженном графике, поэтому каждая строчка кода имеет значение.

Именно в таких ситуациях знание продвинутых методов массивов JavaScript приносит свои плоды.

Эти функции не только сокращают объем кода, но и улучшают производительность, а также прокачивают навыки разработки.

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

10 основных функций массивов

1. forEach()

Вам может понадобиться надежный помощник, который посетит каждый элемент массива и выполнит поставленную задачу. В этом и заключается суть функции forEach().

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

Пример: логирование всех элементов в массиве:

const fruits = ["apple", "banana", "cherry"];

fruits.forEach(fruit => console.log(fruit));

2. map()

Нужно создать новый массив на основе текущего, но особым образом? Функция  map() создает новый массив с результатами применения функции обратного вызова к каждому элементу.

Она идеально подходит для извлечения множеств данных, представления данных и выполнения вычислений.

Пример: удвоение каждого числа в массиве:

const numbers = [1, 2, 3, 4];

const doubledNumbers = numbers.map(number => number * 2);
console.log(doubledNumbers);

// Вывод: [2, 4, 6, 8]

3. filter()

Представьте, что вам необходимо следить за тем, чтобы в VIP-раздел попадали только определенные элементы. filter() создает новый массив, содержащий только те записи, которые прошли тест на основе функции обратного вызова.

Используйте filter() для фильтрации данных по критериям, удаления ненужных элементов или создания пользовательских подмножеств.

Пример: получение четных чисел из массива:

const numbers = [1, 2, 3, 4, 5];

const evenNumbers = numbers.filter(number => number % 2 === 0);
console.log(evenNumbers);

// Вывод: [2, 4]

4. reduce()

reduce() — «мастер боевых искусств», объединяющий целый массив в одно значение с помощью функции обратного вызова.

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

Пример: нахождение суммы массива:

const numbers = [1, 2, 3, 4];

const sum = numbers.reduce((accumulator, current) => accumulator + current, 0);
console.log(sum);

// Вывод: 10

5. find()

Нужно найти первую часть, удовлетворяющую заданному условию? Положитесь в решении этой задачи на find().

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

Пример: поиск первого элемента больше 3:

const numbers = [1, 2, 4, 5];

const firstGreaterThanThree = numbers.find(number => number > 3);
console.log(firstGreaterThanThree);

// Вывод: 4

6. findIndex()

Функция findIndex() на шаг превосходит find(), возвращая индекс первого элемента, прошедшего тест обратного вызова.

Она полезна при поиске определенных данных в массивах, изменении элементов в зависимости от их положения в массиве, а также при выполнении целенаправленных операций.

Пример: поиск индекса первого элемента больше 3:

const numbers = [1, 2, 4, 5];

const indexOfFirstGreaterThanThree = numbers.findIndex(number => number > 3);
console.log(indexOfFirstGreaterThanThree);

// Вывод: 2

7. some()

Вам когда-нибудь требовалось выяснить, содержит ли массив хотя бы одну запись, удовлетворяющую определенному условию? Здесь на помощь приходит функция some().

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

Используйте ее для подтверждения условий, проверки ввода или короткой логики, когда достаточно одного подходящего элемента.

Пример: проверка того, есть ли в массиве элемент больше 10:

const numbers = [1, 5, 8, 12];

const hasElementGreaterThanTen = numbers.some(number => number > 10);
console.log(hasElementGreaterThanTen);

// Вывод: true

8. every()

Функция every() — «строгая старшая сестра» some(). Она обеспечивает прохождение всеми записями массива тест, заданный функцией обратного вызова.

Это полезно для проверки данных, проверки каждого элемента на соответствие заданной структуре и проверки качества.

Пример: проверка того, являются ли все элементы массива строками:

const data = ["apple", "banana", 10];

const allStrings = data.every(element => typeof element === "string");
console.log(allStrings);

// Ou: false

9. include()

Иногда просто нужно узнать, существует ли определенное значение в массиве. include() — лучший помощник в деле простых проверок достоверности.

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

Пример: проверка наличия в массиве значения «orange»:

const fruits = ["apple", "banana", "cherry"];

const hasOrange = fruits.includes("orange");
console.log(hasOrange);

// Вывод: false

10. flat()

Вы когда-нибудь видели многомерные, или вложенные друг в друга, массивы? Они могут быть беспорядочными. Функция flat() помогает преобразовать их в одномерный массив.

Это полезно для упрощения вложенных массивов, работы с данными из API, которые могут иметь вложенные структуры, и хранения данных для дальнейшей обработки.

Пример: преобразование вложенного массива:

const nestedArray = [1, [2, 3], 4];

const flattenedArray = nestedArray.flat();
console.log(flattenedArray);

// Вывод: [1, 2, 3, 4]

Бонусный совет: используйте flatMap() — еще одно недавнее дополнение к JavaScript,- чтобы получить больше контроля над упорядочиванием и преобразованиями.

Продвинутые тактики

Теперь, изучив основные функции, рассмотрим некоторые продвинутые приемы, которые помогут лучше освоить работу с массивами.

Цепочка методов массива

Несколько методов массива можно объединить в цепочку, чтобы внести сложные изменения, которые будут понятны и легко объяснимы.

Например, вы можете отфильтровать массив по четным числам, а затем отобразить их соответствующие квадраты в одной строке:

const numbers = [1, 2, 3, 4, 5];

const evenSquares = numbers.filter(number => number % 2 === 0)
.map(number => number * number);

console.log(evenSquares);

// Вывод: [4, 16]

Пользовательские функции обратного вызова

Помните, что многие функции массива зависят от функции обратного вызова.

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

Например, корректно определенный обратный вызов для проверки четности числа может выглядеть следующим образом:

function isEven(number) {
if (typeof number !== 'number') {
throw new TypeError('Input must be a number');
}
return number % 2 === 0;
}

Обработка ошибок

Неожиданные данные или отсутствующие фрагменты могут привести к ошибкам.

Подумайте, как обрабатывать возможные ошибки в функциях массива, чтобы избежать неожиданного поведения.

Для элегантной обработки исключений можно использовать компонент try-catch:

const numbers = [1, "two", 3];

try {
const doubledNumbers = numbers.map(number => number * 2);
console.log(doubledNumbers);

// [2, NaN, 6] (Error for "two")

} catch (error) {
console

Способы повышения производительности

Не все методы работы с массивами одинаковы. Исследуйте влияние на производительность (например, сравнив циклы forEach и for) больших или сложных массивов. Обратите внимание на следующие параметры:

  • память: большое количество данных может перегрузить вашу систему;
  • циклы: обращение к большому массиву занимает время;
  • сложные элементы: обработка сложных данных в массиве происходит значительно медленнее.

Сравнение циклов ForEach и for: производительность одинаковая, но forEach дает больше контроля и легче читается.

Полезные советы: используйте альтернативные структуры данных для общих процедур поиска, разбивайте большие операции на части и проверяйте код, чтобы найти проблемы (оптимизируйте позже).

Для очень больших наборов данных попробуйте использовать традиционные циклы для повышения эффективности, особенно в старых браузерах, в которых могут быть не оптимизированы реализации функций массивов.

Функциональное программирование

Функции массивов хорошо адаптированы к сфере функционального программирования.

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

Использование методов массивов для создания новых массивов из существующих позволяет сохранять исходные данные в корректном виде, улучшает предсказуемость и облегчает отладку.

Лучшие практики

  • Объединение функций. Как уже говорилось, объединение нескольких задач в цепочку помогает выполнять быстрые и мощные операции. Не бойтесь экспериментировать и комбинировать их для создания сложных изменений в одной строке.
  • Неизменяемость. По возможности старайтесь создавать новые массивы, а не изменять старые. Это улучшает читаемость и снижает риск возникновения нежелательных эффектов. Создавайте новые массивы с помощью таких методов, как mapfilter и slice.
  • Обработка ошибок. Всегда используйте действующий способ обработки ошибок в практике обратных вызовов, чтобы отлавливать случаи странных вводов или отсутствующих элементов. Это позволит избежать накопления ошибок и аварийного завершения программы.

Заключение

Освоение этих 10 методов работы с массивами продвинет вас от новичка в JavaScript далеко вперед (поверьте, ваш уровень повысится).

Вы сможете создавать более понятный, эффективный и гибкий код, который позволит вам работать с данными без особых усилий.

Читайте также:

Читайте нас в Telegram, VK и Дзен


Перевод статьи Rehan Pinjari: 10 JavaScript Array Functions You Should Master as a Senior Dev

Предыдущая статьяСовместное использование данных WebSocket в режиме реального времени в нескольких окнах браузера
Следующая статьяКак выбрать между SQL и No-SQL-решениями?