Скажем, у меня есть это
imageList = [100,200,300,400,500];
Что дает мне
[0]100 [1]200
и т.д.
Есть ли способ в JavaScript вернуть индекс со значением?
т.е. Мне нужен индекс 200, я получаю 1.
Скажем, у меня есть это
imageList = [100,200,300,400,500];
Что дает мне
[0]100 [1]200
и т.д.
Есть ли способ в JavaScript вернуть индекс со значением?
т.е. Мне нужен индекс 200, я получаю 1.
Вы можете использовать indexOf
:
var imageList = [100,200,300,400,500];
var index = imageList.indexOf(200); // 1
Вы получите -1, если не сможете найти значение в массиве.
Для массива объектов используйте map
с indexOf
:
var imageList = [
{value: 100},
{value: 200},
{value: 300},
{value: 400},
{value: 500}
];
var index = imageList.map(function (img) { return img.value; }).indexOf(200);
console.log(index);
Использовать функцию jQuery jQuery.inArray
jQuery.inArray( value, array [, fromIndex ] )
(or) $.inArray( value, array [, fromIndex ] )
Вот еще один способ найти индекс значения в сложном массиве в javascript. Надежда действительно помогает кому-то. Предположим, что у нас есть массив JavaScript, как показано ниже,
var studentsArray =
[
{
"rollnumber": 1,
"name": "dj",
"subject": "physics"
},
{
"rollnumber": 2,
"name": "tanmay",
"subject": "biology"
},
{
"rollnumber": 3,
"name": "amit",
"subject": "chemistry"
},
];
Теперь, если у нас есть требование выбрать конкретный объект в массиве. Предположим, что мы хотим найти индекс студента с именем Tanmay.
Мы можем сделать это путем итерации по массиву и сравнения значения с заданным ключом.
function functiontofindIndexByKeyValue(arraytosearch, key, valuetosearch) {
for (var i = 0; i < arraytosearch.length; i++) {
if (arraytosearch[i][key] == valuetosearch) {
return i;
}
}
return null;
}
Вы можете использовать эту функцию для поиска индекса определенного элемента, как показано ниже,
var index = functiontofindIndexByKeyValue(studentsArray, "name", "tanmay");
alert(index);
Использовать indexOf
imageList.indexOf(200)
как насчет indexOf
?
alert(imageList.indexOf(200));
Array.indexOf
не работает в некоторых версиях Internet Explorer - есть много альтернативных способов сделать это, хотя... см. этот вопрос/ответ: Как проверить, массив включает объект в JavaScript?
Когда списки не очень длинны, это лучший способ, который я знаю:
function getIndex(val) {
for (var i = 0; i < imageList.length; i++) {
if (imageList[i] === val) {
return i;
}
}
}
var imageList = [100, 200, 300, 400, 500];
var index = getIndex(200);
Можно использовать ES6
функцию Array.prototype.findIndex
.
Метод
findIndex()
возвращает индекс первого элемента в массиве, который удовлетворяет предоставленной функции тестирования. В противном случае возвращается -1.
var fooArray = [5, 10, 15, 20, 25];
console.log(fooArray.findIndex(num=> { return num > 5; }));
// expected output: 1
Найти индекс по свойству объекта.
Чтобы найти индекс по свойству объекта:
yourArray.findIndex(obj => obj['propertyName'] === yourValue)
Например, есть такой массив:
let someArray = [
{ property: 'OutDate' },
{ property: 'BeginDate'},
{ property: 'CarNumber' },
{ property: 'FirstName'}
];
Затем код для поиска индекса необходимого свойства выглядит так:
let carIndex = someArray.findIndex( filterCarObj=>
filterCarObj['property'] === 'CarNumber');
// Instead Of
var index = arr.indexOf(200)
// Use
var index = arr.includes(200);
Обратите внимание: функция Includes - это простой метод экземпляра в массиве, который помогает легко определить, находится ли элемент в массиве (включая NaN в отличие от indexOf).
Вот мое мнение, кажется, что большинство решений людей не проверяют, существует ли элемент, и удаляет случайные значения, если он не существует.
Сначала проверьте, существует ли элемент, ища его индекс. Если он существует, удалить его с помощью своего индекса с использованием сплайсинга метода
elementPosition = array.indexOf(value);
if(elementPosition != -1) {
array.splice(elementPosition, 1);
}