Powiedz, że to mam
imageList = [100,200,300,400,500];
Co mi daje
[0]100 [1]200
itp.
Czy w JavaScript jest jakiś sposób na zwrócenie indeksu z wartością?
Tzn. Chcę indeks za 200 , zwracam 1 .
Powiedz, że to mam
imageList = [100,200,300,400,500];
Co mi daje
[0]100 [1]200
itp.
Czy w JavaScript jest jakiś sposób na zwrócenie indeksu z wartością?
Tzn. Chcę indeks za 200 , zwracam 1 .
Odpowiedzi:
Możesz użyć indexOf
:
var imageList = [100,200,300,400,500];
var index = imageList.indexOf(200); // 1
Otrzymasz -1, jeśli nie może znaleźć wartości w tablicy.
W przypadku tablicy obiektów używaj map
z 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);
W nowoczesnych przeglądarkach możesz używać findIndex
:
var imageList = [
{value: 100},
{value: 200},
{value: 300},
{value: 400},
{value: 500}
];
var index = imageList.findIndex(img => img.value === 200);
console.log(index);
Jest to część ES6 i obsługiwana przez Chrome, FF, Safari i Edge
Użyj funkcji jQuery jQuery.inArray
jQuery.inArray( value, array [, fromIndex ] )
(or) $.inArray( value, array [, fromIndex ] )
Oto inny sposób znalezienia indeksu wartości w złożonej tablicy w javascript. Mam nadzieję, że naprawdę ktoś pomoże. Załóżmy, że mamy tablicę JavaScript w następujący sposób,
var studentsArray =
[
{
"rollnumber": 1,
"name": "dj",
"subject": "physics"
},
{
"rollnumber": 2,
"name": "tanmay",
"subject": "biology"
},
{
"rollnumber": 3,
"name": "amit",
"subject": "chemistry"
},
];
Teraz, jeśli mamy wymóg wyboru konkretnego obiektu w tablicy. Załóżmy, że chcemy znaleźć indeks studenta o nazwisku Tanmay.
Możemy to zrobić, iterując tablicę i porównując wartość pod danym kluczem.
function functiontofindIndexByKeyValue(arraytosearch, key, valuetosearch) {
for (var i = 0; i < arraytosearch.length; i++) {
if (arraytosearch[i][key] == valuetosearch) {
return i;
}
}
return null;
}
Możesz użyć tej funkcji do znalezienia indeksu określonego elementu, jak poniżej,
var index = functiontofindIndexByKeyValue(studentsArray, "name", "tanmay");
alert(index);
Array.indexOf
nie działa w niektórych wersjach Internet Explorera - istnieje wiele alternatywnych sposobów na zrobienie tego ... zobacz to pytanie / odpowiedź: Jak sprawdzić, czy tablica zawiera obiekt w JavaScript?
Możliwe jest użycie ES6
funkcji Array.prototype.findIndex
.
MDN mówi :
findIndex()
Sposób powraca indeks pierwszego elementu w układzie, który spełnia podaną funkcję testowania. W przeciwnym razie zwracane jest -1.
var fooArray = [5, 10, 15, 20, 25];
console.log(fooArray.findIndex(num=> { return num > 5; }));
// expected output: 1
Znajdź indeks według właściwości obiektu.
Aby znaleźć indeks według właściwości obiektu:
yourArray.findIndex(obj => obj['propertyName'] === yourValue)
Na przykład istnieje taka tablica:
let someArray = [
{ property: 'OutDate' },
{ property: 'BeginDate'},
{ property: 'CarNumber' },
{ property: 'FirstName'}
];
Następnie kod znajdujący indeks niezbędnej właściwości wygląda następująco:
let carIndex = someArray.findIndex( filterCarObj=>
filterCarObj['property'] === 'CarNumber');
Oto moje zdanie, wygląda na to, że większość ludzi nie sprawdza, czy element istnieje, i usuwa losowe wartości, jeśli nie istnieje.
Najpierw sprawdź, czy element istnieje, szukając jego indeksu . Jeśli istnieje, usuń go według indeksu, używając metody łączenia
elementPosition = array.indexOf(value);
if(elementPosition != -1) {
array.splice(elementPosition, 1);
}
Tablica referencyjna:
var array = [
{ ID: '100', },
{ ID: '200', },
{ ID: '300', },
{ ID: '400', },
{ ID: '500', }
];
Korzystanie filter
i 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]);
Pętle przez każdy element w tablicy za pomocą 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);
Uwaga : Funkcja „Obejmuje” jest prostą metodą instancji w tablicy i pomaga łatwo sprawdzić, czy element znajduje się w tablicy (w tym NaN w przeciwieństwie do indexOf)