.find()

Время чтения: 5 мин

Кратко

Секция статьи "Кратко"

Метод массива find вернёт первый найденный в массиве элемент, который подходит под условие в переданной колбэк-функции. Если в массиве не найдётся ни одного подходящего элемента, то вернётся значение undefined.

Пример

Секция статьи "Пример"

Опишем функцию, которая позволит определить, есть ли в списке дел моё любимое занятие. Поставим в константу просмотр сериальчиков и будем проверять: если занятие из ToDo-списка совпадает с моим хобби, то вернём его. В списке дел на завтра нет просмотра сериалов, а значит, вернётся undefined.

        
          
          function isMyFavoriteHobby(element, index, array) {  const myFavoriteHobby = "смотреть сериальчики";  return element === myFavoriteHobby;}const currentToDoList = [  "смотреть сериальчики",  "читать книгу",  "пить кофе",  "гладить кота",  "гулять",];const tomorrowToDoList = [  "читать книгу",  "пить кофе",  "гладить кота",  "гулять",];// Результат выполнения: смотреть сериальчикиconsole.log(currentToDoList.find(isMyFavoriteHobby));// Результат выполнения: undefined, не найденоconsole.log(tomorrowToDoList.find(isMyFavoriteHobby));
          function isMyFavoriteHobby(element, index, array) {
  const myFavoriteHobby = "смотреть сериальчики";

  return element === myFavoriteHobby;
}

const currentToDoList = [
  "смотреть сериальчики",
  "читать книгу",
  "пить кофе",
  "гладить кота",
  "гулять",
];
const tomorrowToDoList = [
  "читать книгу",
  "пить кофе",
  "гладить кота",
  "гулять",
];

// Результат выполнения: смотреть сериальчики
console.log(currentToDoList.find(isMyFavoriteHobby));

// Результат выполнения: undefined, не найдено
console.log(tomorrowToDoList.find(isMyFavoriteHobby));

        
        
          
        
      

Интерактивный пример

Секция статьи "Интерактивный пример"
Открыть демо в новой вкладке

Как пишется

Секция статьи "Как пишется"

В метод find необходимо передать аргументом функцию. Функция должна возвращать булевое значение true или false. find вернёт первый элемент, на котором переданная функция-колбэк вернула true.

Чтобы получить необходимый элемент, нужно определить условие поиска. В этом нам поможет функция-предикат. Предикат — это функция, которая возвращает булевое значение.

От результата выполнения функции зависит, вернёт ли find подходящий элемент:

  • true — элемент проходит проверку.
  • false — элемент не проходит проверку.

Опишем функцию-предикат isOdd, которая проверяет, является ли число нечётным: проверим остаток от деления на 2, и если остаток равен 1, то число нечётное. Протестируем функцию на двух наборах данных. Первый набор состоит только из чётных значений. Второй массив включает в себя нечётные значения: 17, 19, 21.

Когда мы запустим метод find у первого массива, то нам вернётся undefined, так как ни одно значение не подходит под условие. В случае со вторым набором вернётся число 17 и только оно, потому что это число первое удовлетворило значению.

        
          
          // Если четное - вернёт false, если нечетное - trueconst isOdd = (element) => {  return element % 2 === 1;};const onlyEvenElements = [2, 4, 8, 16, 32];const withOddElements = [2, 4, 8, 16, 17, 19, 21];// Результат выполнения: undefined, не найденоconsole.log(onlyEvenElements.find(isOdd));// Результат выполнения: 17console.log(withOddElements.find(isOdd));
          // Если четное - вернёт false, если нечетное - true
const isOdd = (element) => {
  return element % 2 === 1;
};

const onlyEvenElements = [2, 4, 8, 16, 32];
const withOddElements = [2, 4, 8, 16, 17, 19, 21];

// Результат выполнения: undefined, не найдено
console.log(onlyEvenElements.find(isOdd));

// Результат выполнения: 17
console.log(withOddElements.find(isOdd));

        
        
          
        
      

Функция, которую мы передаём в метод find, принимает три параметра:

  • element — элемент массива в текущей итерации;
  • index — индекс текущего элемента;
  • arr — сам массив, который перебираем.

В коде isOdd мы не стали объявлять параметры index и arr, потому что не используем их.

Как это понять

Секция статьи "Как это понять"

Метод find возвращает элемент, который соответствует описанному в функции-предикате условию. Реализовать такую логику можно и через for, но метод find позволяет это сделать проще.

Ниже показан пример того, как решить задачу без find. Если мы уберём число 2 из массива, то функция будет возвращать undefined. Обратите внимание: после того, как нужный элемент был найден, делается прерывание цикла for. Это написано для имитации поиска через find. find заканчивает работу, как только нашёл нужный элемент. Это называется оптимизация. Не стоит тратить ресурс на то, что уже сделано и не пригодится в дальнейшем.

        
          
          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];      break;    }  }  return undefined;};// Результат выполнения: 2console.log(findTwo(numbersWithTwo));// Результат выполнения: undefinedconsole.log(findTwo(numbersWithoutTwo));
          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];
      break;
    }
  }

  return undefined;
};

// Результат выполнения: 2
console.log(findTwo(numbersWithTwo));

// Результат выполнения: undefined
console.log(findTwo(numbersWithoutTwo));

        
        
          
        
      

find позволит писать меньше кода и сделать его более понятным:

        
          
          const numbers = [1, 2, 3, 4, 5, 6];const result = numbers.find(function isElementEquals2(element) {  return element === 2;});// Результат выполнения: 2console.log(result);
          const numbers = [1, 2, 3, 4, 5, 6];

const result = numbers.find(function isElementEquals2(element) {
  return element === 2;
});

// Результат выполнения: 2
console.log(result);

        
        
          
        
      

Функции filter и find похожи. Главное отличие find от filter в том, что find возвращает первый подходящий элемент, а filter вернёт массив со всеми подходящими элементами.

Вариант реализации через filter:

        
          
          const isElementEquals2Or4 = (element) => {  return (element === 2) || (element === 4);})const numbers = [1, 2, 3, 4, 5, 2, 6];const resultWithFilter = numbers.filter(isElementEquals2Or4(element));const resultWithFind = numbers.find(isElementEquals2Or4(element));// Результат выполнения: [2, 4, 2]console.log(resultWithFilter);// Результат выполнения: 2console.log(resultWithFind);
          const isElementEquals2Or4 = (element) => {
  return (element === 2) || (element === 4);
})

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

const resultWithFilter = numbers.filter(isElementEquals2Or4(element));
const resultWithFind = numbers.find(isElementEquals2Or4(element));

// Результат выполнения: [2, 4, 2]
console.log(resultWithFilter);

// Результат выполнения: 2
console.log(resultWithFind);