JavaScript masīvs lastIndexOf ()

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 searchElementar 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 ()

Interesanti raksti...