W jaki sposób stworzyć nawigację obsługiwaną za pomocą klawiatury w jQuery?
Podstawowym elementem każdej strony internetowej jest odpowiedni system nawigacji. W większości przypadków realizowany jest on za pomocą różnego typu stylizowanych i wizualizowanych pasków menu, obsługiwanych przede wszystkim za pomocą kursora myszki. Spróbujmy na chwilę odejść więc od tej normy i w ramach ćwiczenia jQuery stwórzmy nawigację działającą także z poziomu poszczególnych przycisków klawiatury.
Zarys teoretyczny
Problem możnaby rozwiązać za pomocą samego JavaScriptu i odpowiednich właściwości obiektu event. Idąc jednak z duchem czasu, postaram się wyjaśnić poruszany temat, używając także frameworku jQuery.
W bibliotece tej znajdziemy trzy podstawowe typy zdarzeń, dzięki którym można obsługiwać wciśnięcia przycisków na klawiaturze:
- keydown wywoływane w momencie wciśnięcia klawisza,
- keypress wywoływane w momencie wpisania znaku z klawiatury w dany element strony,
- keyup wywoływane w momencie zwolnienia przycisku.
Są to oczywiście ogólnie przyjęte definicje, gdyż implementacja tych zdarzeń może się w pewnym stopniu różnić w różnego typu silnikach przeglądarek.
Dla naszych potrzeb będziemy używać keypress. Obsługuje ono jednak tylko klawisze alfanumeryczne, co za tym idzie – jeżeli ktoś chciałby używać przycisków takich jak [Ctrl] czy [Shift], musiałby skorzystać z keydown.
Wszystkie trzy zdarzenia mają zbliżoną konstrukcję, którą pokazujemy poniżej.
$(obiekt).zdarzenie(function(parametr) {
if ( parametr.which == KOD_ASCII
|| parametr.keyCode == KOD_ASCII) {
alert(ZNAK);
}
});
Właściwość which jest dostępna i w keydown, i w keypress. Za to keyCode tylko w tym pierwszym. Należy także pamiętać, że keyCode w przypadku znaków alfabetycznych zwraca kod ASCII wielkich liter (od 65 do 90). W przypadku keypress są to odpowedniki małych liter.
$(document).keypress(function(e) {
if ( e.which == 100 ) {
alert(‘d’);
}
});
$(document).keydown(function(e) {
if ( e.keyCode == 68 ) {
alert(‘D’);
}
});
Agregator treści RSS z nawigacją klawiszową
Aby wytłumaczyć działanie powyższych zdarzeń, zbudujmy prosty agregator skróconych treści RSS ostatnich 9 publikacji blogów na Webhostingu. Pominę oczywiście kwestię samego kodu PHP odpowiedzialnego za syndykowanie treści, gdyż ogranicza się ona praktycznie do odpowiedniego załadowania XML, posługując się klasą DOMDocument. Nie to jest jednak przedmiotem tej porady.
Rysunek 1: przykładowy szablon.
Na początku należy pobrać bibliotekę jQuery, a także utworzyć odpowiednią strukturę xHTML naszego przykładu. Niech to będzie dwukolumnowa strona z nawigacją rozmieszczoną po lewej stronie i treścią po prawej.
<div id="container">
<div id="navigation">
<ul>
<li id="nav_id_0" class="selected_tab"><a href="javascript:changeTab('menu', 0);">Nagłówek pierwszy</a></li> <li id="nav_id_1"><a href="javascript:changeTab('menu', 1);">Nagłówek drugi</a></li>
</ul>
</div>
<div class="tabs" id="tab_id_0">
<h2>Nagłówek pierwszy</h2>
<p>Treść pierwsza</p>
</div>
<div class="tabs_invisible" id="tab_id_1">
<h2>Nagłówek drugi</h2>
<p>Treść druga</p>
</div>
</div>
Nadrzędny tag pozwoli na wyśrodkowanie całej strony. Pierwszy potomek o identyfikatorze navigation jest wspominanym już menu.
Wewnątrz jego listy możemy zauważyć kolejne identyfikatory które będą służyć do określenia aktywnego elementu poprzez nadanie mu klasy selected_tab oraz odnośniki w postaci JavaScriptowej funkcji określające typ akcji oraz identyfikator pozycji w menu. Dzięki temu będziemy mogli obsługiwać skrypt nie tylko z poziomu klawiatury, ale także klasycznie.
«poprzednia 1 2 następna »
Popularne
Nazwa padła ofiarą szantażystów, inni polscy hosterzy też zagrożeni?
22
Darmowy Internet od Aero2. Jak go zdobyć i jakie są prawdziwe koszta? Instrukcja krok po kroku
11
Programowanie w środowisku Android – wprowadzenie do projektowania aplikacji dla urządzeń mobilnych
17
Premiera Diablo 3 wzbudziła dyskusję na temat gier, które zawsze chcą być online
19
Nowy problem z Windows 8: bootuje się za szybko
10
Amerykańscy rodzice straszeni „e-narkotykami” dostępnymi w Sieci
21
Anonymous upubliczniają 1,7 GB danych wykradzionych Departamentowi Sprawiedliwości USA
12
Blueseed: libertariańska sztuczna wyspa przyciągnęła już ponad sto startupów z całego świata
8
Rewolucja w Firefoksie, nowa łatka czterokrotnie ograniczyła zużycie pamięci
20
Darmowy Internet od Aero2. Jak go zdobyć i jakie są prawdziwe koszta? Instrukcja krok po kroku
11
CVDazzle: makijaż jest w stanie pokonać automatyczne systemy ulicznego monitoringu
3
Programowanie w środowisku Android – wprowadzenie do projektowania aplikacji dla urządzeń mobilnych
17
Ubuntu 12.04 LTS już dostępny: stabilna dystrybucja na następne pięć lat?
28
Zostań webmasterem polskiego rządu, zarobisz na komfortowe życie dla siebie i swojej rodziny
33
Społeczność
muniu aaaaaaaaaaaaaaaaa
miszczu Wspaniała technologia! Dzięki niej zawsze będziesz patrzył w kierunku w...
miszczu Tytuł nie oddaje rzeczywistości jak zwykle. Mimo wszystko Microsoft...
mistrz autor jest samobójcą, używa internet explorera
boemund_2 Bardzo dobrze. Na dzień dzisiejszy posiadacz VS2010 za prawie 3 tysiaki...
Fox @Wszerad
W obydwu przypadkach piszesz jednak o filmach przyrodniczych ;)
WebDev Uważam, że lepiej pisać aplikacje okienkowe stosując przenośne biblioteki...
- Najdmen.pl: Konta www z wyłączonym licznikiem transferu od IONIC.pl (1)
- 2BE.PL: [Oferta] Promocja jak złoto w 2BE.PL (1)
- gardius: Dobra hurtownia sportowa (1)
- gardius: Tanie książki gdzie warto kupować? (1)
- Najdmen.pl: PROMOCJA, 500 DOMEN .EU ZA 1 PLN NETTO ! (1)
- VMLine: [Oferta] Serwery VPS Xen-HVM/OpenVZ z darmową administracją (2)
- Marek: Generowanie PDFa (2)
Polecane książki
Praca
Czytaj Webhosting
Chcesz być na bieżąco z naszymi informacjami? Zapisz się na Newsletter.
Zarejestruj domenę
Sprawdź dostępność swojej domeny:
| .pl: | 0 zł | .com: | 19.90 zł | |
|---|---|---|---|---|
| .com.pl: | 0 zł | .eu: | 19.90 zł |









