Как узнать индекс элемента в массиве js
Чтобы узнать индекс элемента в массиве в JS, можно воспользоваться методом indexOf()
. Этот метод вернёт первый индекс, по которому указанный элемент находится в массиве:
const beasts = ['ant', 'bison', 'camel', 'duck', 'bison'];
console.log(beasts.indexOf('bison')); // => 1
Если такого элемента в массиве нет, то метод вернет -1
console.log(beasts.indexOf('giraffe')); // => -1
Помимо стандартных возможностей JS, узнать индекс элемента массива можно с помощью метода из библиотеки Lodash _.findIndex():
Метод возвращает индекс первого элемента в массиве, который удовлетворяет условию.
Если ни один из элементов не удовлетворяет условию поиска, возвращается -1. Этот метод отлично ладит с массивами, элементами которых являются объекты. Обратимся к примеру ниже:
const users = [
{ 'user': 'kris', 'active': false },
{ 'user': 'john', 'active': false },
{ 'user': 'luk', 'active': true }
];
const findUserItem = _.findIndex(users, { 'user': 'john', 'active': false });
console.log(findUserItem); // => 1 - индекс искомого элемента
В примере выше всё понятно, давайте посмотрим возможности этого метода в следующем примере.
const findUserItem = _.findIndex(users, ['active', false]);
console.log(findUserItem); // => 0
В примере выше нам не важно имя пользователя, нам просто нужно найти пользователя, у которого был бы неактивный статус. И данный метод нам в этом отлично поможет.
Документация:
_.findIndex()