Metode JavaScript Array lastIndexOf () atgriež pēdējo indeksu, kurā masīvā var atrast noteiktu elementu, vai -1, ja tā nav.
Metodes sintakse lastIndexOf()
ir šāda:
arr.lastIndexOf(searchElement, fromIndex)
Lūk, arr ir masīvs.
parametri lastIndexOf ()
lastIndexOf()
Metode ņem in:
- searchElement - elements, kuru atrast masīvā.
- fromIndex (pēc izvēles) - indekss, lai sāktu meklēšanu atpakaļ. Pēc noklusējuma tas ir masīvs.length - 1 .
Atgriezt vērtību no lastIndexOf ()
- Atgriež masīva elementa pēdējo indeksu, ja tas atrodas vismaz vienu reizi.
- Atgriež -1, ja elements nav atrodams masīvā.
Piezīme. lastIndexOf()
Salīdzina searchElement
ar masīva elementiem, izmantojot stingru vienlīdzību (līdzīgi operatoram trīskāršs ir vienāds ar ===
).
1. piemērs: Metodes lastIndexOf () izmantošana
var priceList = (10, 8, 2, 31, 10, 1, 65); // lastIndexOf() returns the last occurance var index1 = priceList.lastIndexOf(31); console.log(index1); // 3 var index2 = priceList.lastIndexOf(10); console.log(index2); // 4 // second argument specifies the backward search's start index var index3 = priceList.lastIndexOf(10, 3); console.log(index3); // 0 // lastIndexOf returns -1 if not found var index4 = priceList.lastIndexOf(69.5); console.log(index4); // -1
Rezultāts
3 4 0 -1
Piezīmes:
- Ja fromIndex <0 , indekss tiek aprēķināts atpakaļ. Piemēram, -1 apzīmē pēdējo elementu utt.
- Ja aprēķina indeksu, ti, masīvs.length + fromIndex <0 , tiek atgriezta -1 .
2. piemērs: visu elementa gadījumu atrašana
function findAllIndex(array, element) ( indices = (); var currentIndex = array.lastIndexOf(element); while (currentIndex != -1) ( indices.push(currentIndex); if (currentIndex> 0) ( currentIndex = array.lastIndexOf(element, currentIndex - 1); ) else ( currentIndex = -1; ) ) return indices; ) var priceList = (10, 8, 2, 31, 10, 1, 65, 10); var occurance1 = findAllIndex(priceList, 10); console.log(occurance1); // ( 7, 4, 0 ) var occurance2 = findAllIndex(priceList, 8); console.log(occurance2); // ( 1 ) var occurance3 = findAllIndex(priceList, 9); console.log(occurance3); // ()
Rezultāts
(7, 4, 0) (1) ()
Lūk, tad if (currentIndex> 0)
apgalvojums ir pievienots tā, ka atgadījumi indekss 0 nedos -1 par currentIndex - 1
. Tas atkal novestu pie meklēšanas no aizmugures, un programma tiktu iekļauta bezgalīgā lokā.
3. piemērs: atrast citu elementu. Elementa pievienošana
function checkOrAdd(array, element) ( if (array.lastIndexOf(element) === -1) ( array.push(element); console.log("Element not Found! Updated the array."); ) else ( console.log(element + " is already in the array."); ) ) var parts = ("Monitor", "Keyboard", "Mouse", "Speaker"); checkOrAdd(parts, "CPU"); // Element not Found! Updated the array. console.log(parts); // ( 'Monitor', 'Keyboard', 'Mouse', 'Speaker', 'CPU' ) checkOrAdd(parts, "Mouse"); // Mouse is already in the array.
Rezultāts
Elements nav atrasts! Atjaunināja masīvu. ('Monitor', 'Keyboard', 'Mouse', 'Speaker', 'CPU') Pele jau atrodas masīvā.
Ieteicamie lasījumi:
- JavaScript masīvs
- JavaScript Array.indexOf ()