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