Events - myszka
Do zdarzeń, które wywołuje kursor myszki zaliczamy:
mouseup
przycisk myszki został puszczony
click
przycisk myszki został naciśnięty i puszczony (czyli normalne kliknięcie)
dblclick
podwójne kliknięcie
mousemove
kursor porusza się po elemencie
mouseover
kursor znalazł się na elemencie
mouseout
kursor opuścił dany element
mouseenter
kursor znalazł się na elemencie
mouseleave
kursor opuścił dany element
contextmenu
zdarzenie odpalane po kliknięciu prawego guzika myszy (jak otwieranie podręcznego menu)
Zdarzenia mousedown, mouseup, click
Zdarzenia te są związane z kliknięciem przyciskiem myszki na dany obiekt.
Istnieje pewna różnica miedzy click i mousedown. Przypuśćmy, że użytkownik nacisnął guzik na buttonie, następnie przesunął kursor poza ten button i puścił przycisk myszki. Button zarejestrował tylko zdarzenie mousedown. Podobnie - jeżeli użytkownik naciśnie guzik myszki poza buttonem, przesunie kursor na button i wtedy puści przycisk myszki, to button zarejestruje tylko zdarzenie mouseup.
W Windows dla większości przycisków stosowane jest zdarzenie click. Sprawdź sam - kliknij na którymś z guzików w prawym górnym rogu dowolnego okna (np. na zamykającym [X]), a następnie nie puszczając przycisku zjedź kursorem z tego guzika. Okno się nie zamknie, bo nie zaistniało zdarzenia click, tylko zdarzenie mousedown.
element.addEventListener("mousedown", () => {...});
element.addEventListener("mouseup", () => {...});
element.addEventListener("click", () => {...});Kliknij i sprawdź Czyść textarea#
Zdarzenia mouseover, mousemove, mouseout
Zdarzenia mouseover, mousemove i mouseout służą do sprawdzenia, czy użytkownik najechał kursorem na element, czy się po nim porusza lub czy z kursorem opuścił dany element.
Najedź kursorem i sprawdź w konsoli
mouseenter, mouseleave
Istnieją też bardzo podobne zdarzenia czyli mouseenter i mouseleave. Różnią się one tym od swoich braci, że nie są odpalane dla dzieci danego elementu.
Testowy link
Testowy link
Testowy link
Testowy link
Testowy link
Dodatkowe informacje
Tak jak w poprzednim rozdziale, aby pobrać dodatkowe informacje o zaistniałym zdarzeniu, wystarczy, że wypiszemy w konsoli wartość przekazanego do naszej funkcji parametru:
Kliknij i sprawdź
Jak zobaczysz, masz dostęp do wielu przydatnych właściwości. Te najczęściej używane omówimy sobie poniżej.
Pozycja kursora
Aby pobrać pozycję kursora na stronie możemy skorzystać z kilku par właściwości:
e.pageX e.pageY
Zwraca pozycje X, Y kursora od górnego lewego narożnika strony
e.clientX e.clientY
Zwraca pozycję X, Y kursora od lewej krawędzi widocznego obszaru strony (bez uwzględnienia pozycji przewinięcia strony)
e.screenX e.screenY
Zwraca pozycję X, Y na ekranie monitora (jeżeli masz wiele ekranów to od lewego górnego rogu ekranu leżącego najdalej po lewej stronie)
e.layerX e.layerY
Zwraca pozycję X, Y na warstwie renderowania. Nie są to standardowe właściwości (1)
e.offsetX e.offsetY
Zwraca pozycję X, Y kursora na od lewego górnego narożnika danego elementu
x y
W nowych wersjach przeglądarek są to aliasy dla clientX i clientY
Najedź by pokazać pozycję kursora
W większości przypadków głównie będziesz korzystać z właściwości e.pageX, e.pageY lub ewentualnie e.offsetX i e.offsetY. Wynika to z prostego faktu - zazwyczaj będziesz chciał pozycjonować jakieś elementy względem kursora, a pozycjonowanie takie robimy względem całej strony, a nie danego widoku.
Który przycisk myszki
Aby odczytać, który przycisk został naciśnięty skorzystamy z właściwości e.button oraz e.buttons. W przypadku tej drugiej możemy dodatkowo zareagować gdy oba przyciski myszy są naciśnięte równocześnie.
Kliknij RMB by pokazać który klawisz został naciśnięty
Przykład: celownik
Mając powyższe informacje, bez problemu moglibyśmy zrobić celownik na jakimś elemencie.
Użyte właściwości e.offsetX i e.offsetY wskazują na pozycję kursora względem najechanej warstwy. By nie była ona liczona względem celownika a planszy po której jeździmy musimy dodać mu właściwość CSS pointer-events: none:
Przykład: menu kontekstowe
Zbierzmy kilka powyższych informacji, i zróbmy własne kontekstowe menu.
Kliknij prawym by pokazać menu kontekstowe
Nasze menu to zwykła lista UL pozycjonowana absolutnie. Domyślnie wysuwamy ją totalnie za ekran ustawiając top i left na -9999:
Dodajemy pokazywanie naszego menu po kliknięciu prawym przyciskiem na div:
Jeżeli teraz klikniemy prawym przyciskiem myszy na div, faktycznie nasze menu się pojawi, ale też pojawi się domyślne menu. Żeby domyślne menu się nie pokazywało, powinniśmy użyć pewnie e.preventDefault(). I faktycznie - tyle tylko, że musimy zatrzymać event contextmenu:
Ostatnią rzeczą jaką musimy zrobić to możliwość schowania menu poprzez kliknięcie lewym przyciskiem myszy w dowolne miejsce na stronie i podczas przewijania strony (przynajmniej u mnie gdy zacznę przewijać stronę klasyczne menu się chowa):
Element menu 1
Element menu 2
Element menu 3
Element menu 4
Powyższe rozwiązanie jest prostym przykładem. W większych projektach prawdopodobnie o wiele lepiej sprawdzi się gotowy plugin np. https://github.com/electerious/basicContext
Last updated