MooTools - selektory

Selektory służą do wybierania elementów HTML. Zawsze, gdy chcesz tworzyć interaktywne strony internetowe, musisz wybrać jakieś dane lub akcję z tej strony. Selektory pomagają nam otrzymywać dane poprzez żądanie HTML z elementów.

Podstawowy selektor ($)

Plik $to podstawowy selektor w MooTools. Używając tego, możesz wybrać element DOM według jego identyfikatora. Na przykład załóżmy, że masz nazwany element HTML (taki jak div)body_id.

<div id = "body_id">

</div>

Jeśli chcesz wybrać ten element div, użyj następującej składni -

Składnia

//selects the element with the ID 'body_id'
$('body_id');

getElement ()

getElement () to metoda, która rozszerza podstawowy selektor ($). Pozwala zawęzić wybór za pomocą identyfikatora elementu. getElement () wybiera tylko pojedynczy element i zwróci pierwszy, jeśli istnieje wiele opcji. Możesz również użyć nazwy klasy, aby uzyskać pierwsze wystąpienie elementu. Ale nie otrzyma tablicy elementów.

Selektor wielokrotny ($$)

$$ służy do wybierania wielu elementów i umieszczania tych wielu elementów w tablicy. Z tej tablicy możemy manipulować listą, pobierać ją i zmieniać jej kolejność na różne sposoby. Spójrz na następującą składnię. Definiuje sposób wybierania wszystkich elementów div z kolekcji elementów HTML na stronie internetowej.

Składnia

<div>
   <div>a div</div>
   <span id = "id_name">a span</span>
</div>

Jeśli chcesz zaznaczyć wszystkie elementy div, użyj następującej składni -

Składnia

//all divs in the page
$$('div');

Jeśli chcesz wybrać wiele elementów DIV o tej samej nazwie identyfikatora, użyj następującej składni -

Składnia

//selects the element with the id 'id_name' and all divs
$$('#id_name', 'div');

getElements ()

Metoda getElements () jest podobna do metody getElement (). Ta metoda zwraca wszystkie elementy zgodnie z kryteriami. Możesz użyć jednego z nichelement name (a, div, input) aby wybrać te kolekcje lub określony element class name do wybierania kolekcji elementów tej samej klasy.

Uwzględnij i wyklucz wyniki za pomocą operatorów

MooTools obsługuje różne operatory używane do zawężania wybranych opcji. Możesz użyć wszystkich tych operatorów w metodzie getElements (). Każdy z tych operatorów może służyć do wybierania elementu wejściowego według nazwy.

Spójrz na poniższą tabelę. Definiuje różne operatory obsługiwane przez MooTools.

Operator Opis Przykład
= (równe) Wybierz element wejściowy według jego nazwy. $ ('body_wrap'). getElements ('input [nazwa = numer_telefonu]');
^ = (zaczyna się od) Wybierz element wejściowy, porównując jego początkowe litery nazwy. $ ('body_wrap'). getElements ('input [name ^ = phone]');
$ = (kończy się na) Wybierz element wejściowy, porównując końcowe litery nazwy. $ ('body_wrap'). getElements ('input [nazwa $ = numer]');
! = (nie równa się) Usuń zaznaczenie elementu wejściowego według nazwy. $ ('body_wrap'). getElements ('input [nazwa! = adres]');
* = (Zawiera) Wybierz element wejściowy, który zawiera określony wzór liter. $ ('body_wrap'). getElements ('input [name * = phone]');

Selektory oparte na kolejności elementów

Selektory MooTools zachowują określoną kolejność w wyborze elementów. Selektory wykonują głównie dwa porządki; jeden jest parzysty, a drugi jest nieparzysty.

Note - Ten selektor zaczyna się od 0, więc pierwszy element jest parzysty.

Nawet porządek

W tej kolejności selektor wybiera elementy, które są ułożone w równej kolejności. Użyj poniższej składni, aby wybrać wszystkie parzyste elementy div na swojej stronie HTML.

Syntax

// selects all even divs
$$('div:even');

Dziwne zamówienie

W tej kolejności selektor wybiera element umieszczony w nieparzystej kolejności. Użyj następującej składni, aby zaznaczyć wszystkie nieparzyste elementy div na stronie HTML.

Syntax

// selects all odd divs
$$('div:odd');

Example

Poniższy przykład pokazuje, jak działa selektor. Załóżmy, że na stronie internetowej znajduje się pole tekstowe i lista technologii. Jeśli wybierzesz jedną technologię z listy, wprowadzając tę ​​nazwę w polu tekstowym, lista wyświetli przefiltrowane wyniki na podstawie wprowadzonych danych. Jest to możliwe za pomocą selektora MooTools. Za pomocą selektora możemy dodać zdarzenie do pola tekstowego. Odbiornik zdarzeń wybierze dane z pola tekstowego i sprawdzi je z listy. Jeśli znajduje się na liście, lista zawiera przefiltrowane wyniki. Spójrz na poniższy kod.

<html>

   <head>
      <script type = "text/javascript" src = "MooTools-Core-1.6.0.js"></script>
      <script type = "text/javascript" src = "MooTools-More-1.6.0.js"></script>
      
      <script type = "text/javascript">
         window.addEvent('domready',function(){
            var input = $('filter');
            
            // set the title attribute of every element
            // to it's text in lowercase
            $$('ul > li').each(function(item){
               item.set('title', item.get('text').toLowerCase());
            });
            
            // the function we'll call when the user types
            var filterList = function(){
               var value = input.value.toLowerCase();
               $$('li').setStyle('display','none');
               
               // check the title attribute if it contains whatever the user is typing
               $$('ul > li[title*=' + value + ']').setStyle('display','');
            };
            
            // make it happen
            input.addEvent('keyup', filterList);
         });
      </script>
   </head>
   
   <body>
      <p><input id = "filter" type = "text" /></p>
      <ul>
         <li>C</li>
         <li>Cpp</li>
         <li>Java</li>
         <li>JavaScript</li>
         <li>Hadoop</li>
         <li>Hive</li>
         <li>CouchDB</li>
      </ul>
   </body>
   
</html>

Otrzymasz następujący wynik -

Output