15 часто используемых методов массивов JavaScript.
Важная особенность методов массивов состоит в том, что они делятся на изменяемые и неизменяемые. Это необходимо учитывать при выборе метода для решения конкретной задачи.
Большинство методов массивов в этом списке принимают в качестве аргумента аналогичный обратный вызов. Первый аргумент — это текущий элемент, второй — индекс, а третий — весь массив. С этим разобрались, теперь приступим к работе со списком. 1. ForEach
Переби?
15 часто используемых методов массивов JavaScript...
Важная особенность методов массивов состоит в том, что они делятся на изменяемые и неизменяемые. Это необходимо учитывать при выборе метода для решения конкретной задачи.
Большинство методов массивов в этом списке принимают в качестве аргумента аналогичный обратный вызов. Первый аргумент — это текущий элемент, второй — индекс, а третий — весь массив. С этим разобрались, теперь приступим к работе со списком.
1. ForEach
Перебирает каждый элемент массива и выполняет функцию обратного вызова.
const arr = [1, 2, 3];
arr.forEach(num => console.log(num));
// Консоль: 1, 2, 3
2. Map
Перебирает каждый элемент массива и выполняет функцию обратного вызова. Создает новый массив с возвращаемыми значениями функции обратного вызова.
const arr = [1, 2, 3, 4, 5];
const areEven = arr.map(num => num % 2 === 0);
console.log(areEven); // Консоль: [false, true, false, true, false]
3. Filter
Перебирает каждый элемент массива и выбирает только те, что соответствуют условию. Возвращается новый массив, основанный на выбранных элементах.
const arr = [1, 2, 3, 4, 5];
const evenNumbers = arr.filter(num => num % 2 === 0);
console.log(evenNumbers); // Консоль[2, 4]
4. Find
Находит первый элемент в массиве, который удовлетворяет условию. Если не найдено ни одного, возвращается значение undefined
.
const arr = [1, 2, 3, 4, 5];
const firstEvenNumber = arr.find(num => num % 2 === 0);
console.log(firstEvenNumber); // Консоль[2]
5. FindIndex
Аналогично предыдущему методу, возвращает индекс первого элемента, удовлетворяющего заданному условию. Если не найдено ни одного, возвращается -1
.
const arr = [1, 2, 3, 4, 5];
const firstEvenNumberIdx = arr.findIndex(num => num % 2 === 0);
console.log(firstEvenNumberIdx);
6. Reduce
Это расширенный метод, который можно использовать для объединения элементов массива. Основное отличие заключается в том, что обратный вызов принимает в качестве первого аргумента аккумулятор. Возвращаемое значение обратного вызова становится аккумулятором при следующей итерации.
const arr = [1, 2, 3, 4, 5];
// `acc` - значение аккумулятора
// аккумулятор - возвращаемое значение предыдущего обратного вызова
// второй аргумент, т.е. `0`, является значением по умолчанию
const sum = arr.reduce((acc, num) => acc + num, 0);
console.log(sum); // Консоль: 15
7. Every
Этот метод принимает обратный вызов, который возвращает булево значение. Every()
вернет true
, если условие справедливо для всех элементов массива.
const arr = [1, 2, 3, 4, 5];
const areAllEven = arr.every(num => num % 2 === 0);
console.log(areAllEven); // Консоль: false
8. Some
Как и предыдущий метод, some
также принимает обратный вызов, который возвращает булево значение. Some()
вернет true
, если условие справедливо хотя бы для одного элемента.
const arr = [1, 2, 3, 4, 5];
const isOneEven = arr.some(num % 2 === 0);
console.log(isOneEven); // true
9. Sort
Этот метод используется для сортировки элементов в массиве. По умолчанию он сортирует массив по возрастанию. Он принимает функцию обратного вызова с двумя элементами — a
и b
. Если a
меньше b
, то возвращается -1
, в ином случае возвращается 1
. Если значения равны, то возвращается 0
.
const arr = [1, 2, 3, 4, 5];
const descendingArr = arr.sort((a, b) => b - a);
console.log(descendingArr);
Помните, что в отличие от других методов,
sort
изменяет массив.
10. Flat
Flat используется для объединения вложенного массива в один массив. Вы можете указать глубину, до которой его нужно “сгладить”.
const arr = [[[1, 2], [3]], [4, 5]];
const flattenedArr = arr.flat(4);
console.log(flattenedArr); // Консоль[1, 2, 3, 4, 5]
11. Reverse
Меняет порядок элементов в массиве.
const arr = [1, 2, 3, 4, 5];
const reversedArr = arr.reverse();
console.log(reversedArr); // Консоль[5, 4, 3, 2, 1]
12. Include
Этот метод возвращает true
, если элемент присутствует в массиве.
const arr = [1, 2, 3, 4, 5];
console.log(arr.includes(5)); // true
console.log(arr.includes(10)); // false
13. Fill
Метод fill
устанавливает элементы массива в заданное значение. Он удобен, когда нужно использовать метод map
/forEach
определенное количество раз.
const emptyArr = new Array(5);
// Проблема в том, что вы получаете `[empty x 10]`.
// Нужны реальные значения, чтобы применить функцию map.
const filledArr = emptyArr.fill(3); // Консоль[3, 3, 3, 3, 3]
14. At
Этот метод возвращает элемент заданного индекса. Разница между ним и традиционным способом доступа к элементу (т.е. arr[1]
) заключается в том, что он поддерживает и отрицательные индексы.
const arr = [1, 2, 3, 4, 5];
console.log(arr.at(1)); // 2
console.log(arr.at(-1)); // 5
// Важно: отрицательные индексы начинаются с `1`, а положительные - с `0`.
15. Concat
Этот метод используется для объединения двух массивов.
const arr1 = [1, 2, 3, 4, 5];
const arr2 = [6, 7, 8, 9, 10];
console.log(arr1.concat(arr2)); // Консоль[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]