Кратко
СкопированоМетод массива find вернёт первый найденный в массиве элемент, который подходит под условие в переданной колбэк-функции. Если в массиве не найдётся ни одного подходящего элемента, то вернётся значение undefined.
Пример
СкопированоОпишем функцию, которая позволит определить, есть ли в списке дел моё любимое занятие. Поставим в константу просмотр сериальчиков и будем проверять: если занятие из ToDo-списка совпадает с моим хобби, то вернём его. В списке дел на завтра нет просмотра сериалов, а значит, вернётся undefined.
function isMyFavoriteHobby(element, index, array) { const myFavoriteHobby = 'смотреть сериальчики' return element === myFavoriteHobby}const currentToDoList = [ 'смотреть сериальчики', 'читать книгу', 'пить кофе', 'гладить кота', 'гулять',]const tomorrowToDoList = [ 'читать книгу', 'пить кофе', 'гладить кота', 'гулять',]console.log(currentToDoList.find(isMyFavoriteHobby))// 'смотреть сериальчики'console.log(tomorrowToDoList.find(isMyFavoriteHobby))// undefined, не найдено
function isMyFavoriteHobby(element, index, array) {
const myFavoriteHobby = 'смотреть сериальчики'
return element === myFavoriteHobby
}
const currentToDoList = [
'смотреть сериальчики',
'читать книгу',
'пить кофе',
'гладить кота',
'гулять',
]
const tomorrowToDoList = [
'читать книгу',
'пить кофе',
'гладить кота',
'гулять',
]
console.log(currentToDoList.find(isMyFavoriteHobby))
// 'смотреть сериальчики'
console.log(tomorrowToDoList.find(isMyFavoriteHobby))
// undefined, не найдено
Интерактивный пример
СкопированоКак пишется
СкопированоВ метод find необходимо передать аргументом функцию. Функция должна возвращать булево значение true или false. find вернёт первый элемент, на котором переданная функция-колбэк вернула true.
Чтобы получить необходимый элемент, нужно определить условие поиска. В этом нам поможет функция-предикат. Предикат — это функция, которая возвращает булево значение.
От результата выполнения функции зависит, вернёт ли find подходящий элемент:
true— элемент проходит проверку.false— элемент не проходит проверку.
Опишем функцию-предикат is, которая проверяет, является ли число нечётным: проверим остаток от деления на 2, и если остаток равен 1, то число нечётное:
const isOdd = (element) => { return element % 2 === 1}
const isOdd = (element) => {
return element % 2 === 1
}
Протестируем функцию на двух наборах данных. Первый набор состоит только из чётных значений. Второй массив включает в себя нечётные значения: 17, 19, 21.
Когда мы запустим метод find у первого массива, то нам вернётся undefined, так как ни одно значение не подходит под условие. В случае со вторым набором вернётся число 17 и только оно, потому что это число первое удовлетворило значению.
const onlyEvenElements = [2, 4, 8, 16, 32]const withOddElements = [2, 4, 8, 16, 17, 19, 21]console.log(onlyEvenElements.find(isOdd))// undefined, не найденоconsole.log(withOddElements.find(isOdd))// 17
const onlyEvenElements = [2, 4, 8, 16, 32]
const withOddElements = [2, 4, 8, 16, 17, 19, 21]
console.log(onlyEvenElements.find(isOdd))
// undefined, не найдено
console.log(withOddElements.find(isOdd))
// 17
Функция, которую мы передаём в метод find, принимает три параметра:
element— элемент массива в текущей итерации;index— индекс текущего элемента;arr— сам массив, который перебираем.
В коде is мы не стали объявлять параметры index и arr, потому что не используем их.
Как понять
СкопированоМетод find возвращает элемент, который соответствует описанному в функции-предикате условию. Реализовать такую логику можно и через for, но метод find позволяет это сделать проще.
Ниже показан пример того, как решить задачу без find. Если мы уберём число 2 из массива, то функция будет возвращать undefined.
const numbersWithTwo = [1, 2, 3, 4, 5, 6]const numbersWithoutTwo = [1, 3, 4, 5, 6]const findTwo = (array) => { for (let i = 0; i < array.length; i++) { if (array[i] === 2) { return array[i] } } return undefined};console.log(findTwo(numbersWithTwo))// 2console.log(findTwo(numbersWithoutTwo))// undefined
const numbersWithTwo = [1, 2, 3, 4, 5, 6]
const numbersWithoutTwo = [1, 3, 4, 5, 6]
const findTwo = (array) => {
for (let i = 0; i < array.length; i++) {
if (array[i] === 2) {
return array[i]
}
}
return undefined
};
console.log(findTwo(numbersWithTwo))
// 2
console.log(findTwo(numbersWithoutTwo))
// undefined
☝️ Обратите внимание: после того, как нужный элемент был найден, из функции find возвращается значение. Это ведёт к прерыванию цикла for. Мы сделали так, чтобы полностью симулировать работу метода find — он заканчивает работу сразу, как только нашёл нужный элемент. Это называется оптимизация. Не стоит тратить ресурс на то, что уже сделано и не пригодится в дальнейшем.
find позволит писать меньше кода и сделать его более понятным:
const numbers = [1, 2, 3, 4, 5, 6]const result = numbers.find(function isElementEquals2(element) { return element === 2});console.log(result)// 2
const numbers = [1, 2, 3, 4, 5, 6]
const result = numbers.find(function isElementEquals2(element) {
return element === 2
});
console.log(result)
// 2
Методы .filter и find похожи. Главное отличие find от filter в том, что find возвращает первый подходящий элемент, а filter вернёт массив со всеми подходящими элементами.
Вариант реализации через .filter:
const isTwoOrFour = (element) => { return (element === 2) || (element === 4)}const numbers = [1, 2, 3, 4, 5, 2, 6]const resultWithFilter = numbers.filter(isTwoOrFour(element))const resultWithFind = numbers.find(isTwoOrFour(element))console.log(resultWithFilter)// [2, 4, 2]console.log(resultWithFind)// 2
const isTwoOrFour = (element) => {
return (element === 2) || (element === 4)
}
const numbers = [1, 2, 3, 4, 5, 2, 6]
const resultWithFilter = numbers.filter(isTwoOrFour(element))
const resultWithFind = numbers.find(isTwoOrFour(element))
console.log(resultWithFilter)
// [2, 4, 2]
console.log(resultWithFind)
// 2