Скажіть, у мене це є
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);
У сучасних браузерах ви можете використовувати findIndex
:
var imageList = [
{value: 100},
{value: 200},
{value: 300},
{value: 400},
{value: 500}
];
var index = imageList.findIndex(img => img.value === 200);
console.log(index);
Його частина ES6 та підтримується Chrome, FF, Safari та Edge
Використовуйте функцію 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"
},
];
Тепер якщо у нас є вимога вибрати певний об'єкт у масиві. Припустимо, що ми хочемо знайти індекс студента з прізвищем Танмай.
Ми можемо зробити це шляхом ітерації через масив та порівняння значення заданого ключа.
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);
Array.indexOf
не працює в деяких версіях Internet Explorer - є багато альтернативних способів зробити це, хоча ... дивіться це питання / відповідь: Як я можу перевірити, чи містить масив об'єкт у JavaScript?
Можна використовувати ES6
функцію Array.prototype.findIndex
.
MDN каже :
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');
Ось мій погляд на це, схоже, що більшість народних рішень не перевіряють, чи існує елемент, і він видаляє випадкові значення, якщо його немає.
Спочатку перевірте, чи існує елемент, шукаючи його індекс . Якщо він існує, видалити його з допомогою свого індексу з використанням сплайсингу методу
elementPosition = array.indexOf(value);
if(elementPosition != -1) {
array.splice(elementPosition, 1);
}
Довідковий масив:
var array = [
{ ID: '100', },
{ ID: '200', },
{ ID: '300', },
{ ID: '400', },
{ ID: '500', }
];
Використання filter
та indexOf
:
var in_array = array.filter(function(item) {
return item.ID == '200' // look for the item where ID is equal to value
});
var index = array.indexOf(in_array[0]);
Переглядаючи кожен елемент у масиві, використовуючи indexOf
:
for (var i = 0; i < array.length; i++) {
var item= array[i];
if (item.ID == '200') {
var index = array.indexOf(item);
}
}
// Instead Of
var index = arr.indexOf(200)
// Use
var index = arr.includes(200);
Зверніть увагу : Функція Includes - це простий метод примірника для масиву і допомагає легко знайти, чи є елемент у масиві (включаючи NaN на відміну від indexOf)