Loading:


    JavaScript lastIndexOf (Metoda obiektu: Array)

    Zwraca ostatni indeks, pod którym podany element może być znaleziony w tablicy, lub -1 jeśli nie jest obecny. Tablica jest przeszukiwana od końca, zaczynając od indeksu fromIndex

    Metoda obiektu: Array

    Składnia


    var index = array.lastIndexOf(searchElement[, fromIndex]);



    Parametry


    searchElement  - Element do znalezienia w tablicy.


    fromIndex  - Indeks od którego ma zostać rozpoczęte wyszukiwanie od tyłu. Domyślnie jest to długość tablicy, tzn. przeszukana zostanie cała tablica. Jeśli indeks jest większy od lub równy długości tablicy, przeszukana zostanie cała tablica. Jeśli jest ujemny, traktowany będzie jako przesunięcie od końca tablicy. Należy pamiętać, że nawet jeśli indeks jest ujemny, to i tak tablica przeszukiwana jest od końca do początku. Jeśli obliczony indeks jest mniejszy od 0, zwracana jest wartość -1, innymi słowy, tablica nie zostanie przeszukana.


    Opis


    lastIndexOf porównuje searchElement z elementami tablicy używając ścisłego porównania (podobnie jak w przypadku operatora ===).

    Kompatybilność


    lastIndexOf jest rozszerzeniem JavaScript dla standardu ECMA-262, więc może nie być obecny w innych implementacjach tego standardu. Można to obejść, dopisując poniższy kod na początku skryptu, zezwalający na użycie lastIndexOf w implementacji ECMA-262, które nie wspierają tego natywnie.

    if (!Array.prototype.lastIndexOf)
    {
      Array.prototype.lastIndexOf = function(elt /*, from*/)
      {
        var len = this.length;

        var from = Number(arguments[1]);
        if (isNaN(from))
        {
          from = len - 1;
        }
        else
        {
          from = (from < 0)
               ? Math.ceil(from)
               : Math.floor(from);
          if (from < 0)
            from += len;
          else if (from >= len)
            from = len - 1;
        }

        for (; from > -1; from--)
        {
          if (from in this &&
              this[from] === elt)
            return from;
        }
        return -1;
      };
    }




    Należy zwrócić uwagę, że ta implementacja ma na celu całkowitą zgodność z lastIndexOf występującą w Firefoksie i silniku JavaScript SpiderMonkey, włączając w to przypadki skrajne. Jeśli masz zamiar wykorzystać przytoczone rozwiązanie w rzeczywistych aplikacjach, możesz obliczyć from za pomocą mniej skomplikowanego kodu (z pominięciem części instrukcji warunkowych).

    Przykłady


    Przykład: Zastosowanie lastIndexOf


    Poniższy przykład używa lastIndexOf do znalezienia określonych wartości w tablicy.

    array = [2, 5, 9, 2];

    index = array.lastIndexOf(2);

    // index is 3

    index = array.lastIndexOf(7);

    // index is -1

    index = array.lastIndexOf(2, 3);

    // index is 3

    index = array.lastIndexOf(2, 2);

    // index is 0

    index = array.lastIndexOf(2, -2);

    // index is 0

    index = array.lastIndexOf(2, -1);

    // index is 3


    Przykład: Wyszukiwanie wszystkich wystąpień danego elementu


    Poniższy przykład używa lastIndexOf do znalezienia wszystkich wystąpień elementu w tablicy oraz dodaje ich indeksy do drugiej tablicy używając metody push.

    indices = [];

    idx = array.lastIndexOf(element)

    while (idx != -1) {

       indices.push(idx);

       idx = (idx > 0 ? array.lastIndexOf(element, idx - 1) : -1);

    }


    Warto zauważyć, że obsłużyliśmy warunek idx == 0 oddzielnie, ponieważ element ten zostanie zawsze odnaleziony - bez względu na wartość parametru fromIndex - w przypadku gdy jest on pierwszym elementem tablicy. To różni tę metodę od metody indexOf.

     



    Napisz Artyku³

    Listing

    niema




    Dodano przez: igor
    Ranga: Administrator serwisu Punktów: 0
    Komentarze użytkowników
      • Tre¶æ komentarza
        Kod do komentarza (opcjonalnie)
        PHP JavaScript MySQL Smarty SQL HTML CSS ActionScript
        Autor
        Token
        token

         

         








    funkcje.net
    Wszelkie prawa zastrzeżone©. | Funkcje.net 2008-2025 v.1.5 | design: diviXdesign & rainbowcolors