Meetod JavaScripti massiivi lastIndexOf () tagastab viimase indeksi, mille juures antud massiivi võib leida, või -1, kui seda pole.
Meetodi süntaks lastIndexOf()
on:
arr.lastIndexOf(searchElement, fromIndex)
Siin on arr massiiv.
parameetrid lastIndexOf ()
lastIndexOf()
Meetod võtab:
- searchElement - element massiivist.
- fromIndex (valikuline) - indeks tagurpidi otsimise alustamiseks. Vaikimisi on see massiiv.length - 1 .
Tagastusväärtus väärtuselt lastIndexOf ()
- Tagastab massiivi elemendi viimase indeksi, kui see on vähemalt üks kord olemas.
- Tagastab -1, kui elementi massiivist ei leia.
Märkus: lastIndexOf()
võrreldakse searchElement
massiivi elementidega, kasutades ranget võrdsust (sarnane operaatorile triple-equals või ===
).
Näide 1: meetodi lastIndexOf () kasutamine
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
Väljund
3 4 0-1
Märkused:
- Kui fromIndex <0 , arvutatakse indeks tagasi. Näiteks tähistab -1 viimast elementi ja nii edasi.
- Kui arvutatud indeks, st massiiv.pikkus + väärtusest Indeks <0 , tagastatakse -1 .
Näide 2: elemendi kõigi esinemiste leidmine
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); // ()
Väljund
(7, 4, 0) (1) ()
Siin if (currentIndex> 0)
avaldus lisatakse nii, et sündmused on indeks 0 ei anna -1 eest currentIndex - 1
. See tooks kaasa jällegi otsimise tagantpoolt ja programm jääks lõputu silmusesse.
Näide 3: selle leidmine, kas element on veel olemas. Elemendi lisamine
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.
Väljund
Elementi ei leitud! Värskendas massiivi. ('Monitor', 'Klaviatuur', 'Mouse', 'Speaker', 'CPU') Hiir on juba massiivis.
Soovitatavad lugemised:
- JavaScripti massiiv
- JavaScripti array.indexOf ()