jQuery - Gestion des événements

Nous avons la possibilité de créer des pages Web dynamiques en utilisant des événements. Les événements sont des actions qui peuvent être détectées par votre application Web.

Voici les exemples d'événements -

  • Un clic de souris
  • Une page Web en cours de chargement
  • Passer la souris sur un élément
  • Soumettre un formulaire HTML
  • Une frappe sur votre clavier, etc.

Lorsque ces événements sont déclenchés, vous pouvez ensuite utiliser une fonction personnalisée pour faire à peu près tout ce que vous voulez avec l'événement. Ces fonctions personnalisées appellent les gestionnaires d'événements.

Gestionnaires d'événements de liaison

En utilisant le modèle d'événement jQuery, nous pouvons établir des gestionnaires d'événements sur les éléments DOM avec le bind() méthode comme suit -

<html>
   <head>
      <title>The jQuery Example</title>
      <script type = "text/javascript" 
         src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
      </script>
		
      <script type = "text/javascript" language = "javascript">
         $(document).ready(function() {
            $('div').bind('click', function( event ){
               alert('Hi there!');
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below to see the result:</p>
		
      <div class = "div" style = "background-color:blue;">ONE</div>
      <div class = "div" style = "background-color:green;">TWO</div>
      <div class = "div" style = "background-color:red;">THREE</div>
   </body>
</html>

Ce code provoquera la réponse de l'élément de division à l'événement de clic; lorsqu'un utilisateur clique à l'intérieur de cette division par la suite, l'alerte sera affichée.

Cela produira le résultat suivant -

La syntaxe complète de la commande bind () est la suivante -

selector.bind( eventType[, eventData], handler)

Voici la description des paramètres -

  • eventType- Une chaîne contenant un type d'événement JavaScript, tel que cliquer ou soumettre. Reportez-vous à la section suivante pour une liste complète des types d'événements.

  • eventData - Ce paramètre facultatif est une carte de données qui sera transmise au gestionnaire d'événements.

  • handler - Une fonction à exécuter chaque fois que l'événement est déclenché.

Suppression des gestionnaires d'événements

En règle générale, une fois qu'un gestionnaire d'événements est établi, il reste en vigueur pour le reste de la vie de la page. Il peut être nécessaire de supprimer le gestionnaire d'événements.

jQuery fournit le unbind()commande pour supprimer un gestionnaire d'événements en cours de sortie. La syntaxe de unbind () est la suivante -

selector.unbind(eventType, handler)

or 

selector.unbind(eventType)

Voici la description des paramètres -

  • eventType- Une chaîne contenant un type d'événement JavaScript, tel que cliquer ou soumettre. Reportez-vous à la section suivante pour une liste complète des types d'événements.

  • handler - S'il est fourni, identifie l'auditeur spécifique à supprimer.

Types d'événements

N ° Sr. Type d'événement et description
1

blur

Se produit lorsque l'élément perd le focus.

2

change

Se produit lorsque l'élément change.

3

click

Se produit lorsqu'un clic de souris.

4

dblclick

Se produit lorsqu'un double-clic de souris.

5

error

Se produit lorsqu'il y a une erreur de chargement ou de déchargement, etc.

6

focus

Se produit lorsque l'élément obtient le focus.

sept

keydown

Se produit lorsque la touche est enfoncée.

8

keypress

Se produit lorsque la touche est enfoncée et relâchée.

9

keyup

Se produit lorsque la clé est relâchée.

dix

load

Se produit lorsque le document est chargé.

11

mousedown

Se produit lorsque le bouton de la souris est enfoncé.

12

mouseenter

Se produit lorsque la souris entre dans une région d'élément.

13

mouseleave

Se produit lorsque la souris quitte une région d'élément.

14

mousemove

Se produit lorsque le pointeur de la souris se déplace.

15

mouseout

Se produit lorsque le pointeur de la souris sort d'un élément.

16

mouseover

Se produit lorsque le pointeur de la souris se déplace sur un élément.

17

mouseup

Se produit lorsque le bouton de la souris est relâché.

18

resize

Se produit lorsque la fenêtre est redimensionnée.

19

scroll

Se produit lorsque la fenêtre défile.

20

select

Se produit lorsqu'un texte est sélectionné.

21

submit

Se produit lorsque le formulaire est soumis.

22

unload

Se produit lorsque les documents sont déchargés.

L'objet événement

La fonction de rappel prend un seul paramètre; lorsque le gestionnaire est appelé, l'objet événement JavaScript lui sera transmis.

L'objet événement est souvent inutile et le paramètre est omis, car un contexte suffisant est généralement disponible lorsque le gestionnaire est tenu de savoir exactement ce qui doit être fait lorsque le gestionnaire est déclenché, mais il y a certains attributs auxquels vous auriez besoin d'accéder.

Les attributs de l'événement

N ° Sr. Propriété et description
1

altKey

Défini sur true si la touche Alt a été enfoncée lorsque l'événement a été déclenché, false dans le cas contraire. La touche Alt est étiquetée Option sur la plupart des claviers Mac.

2

ctrlKey

Défini sur true si la touche Ctrl a été enfoncée lorsque l'événement a été déclenché, false dans le cas contraire.

3

data

La valeur, le cas échéant, transmise comme deuxième paramètre à la commande bind () lors de l'établissement du gestionnaire.

4

keyCode

Pour les événements keyup et keydown, cela renvoie la touche qui a été enfoncée.

5

metaKey

Défini sur true si la touche Meta a été enfoncée lorsque l'événement a été déclenché, false dans le cas contraire. La touche Meta est la touche Ctrl sur les PC et la touche Commande sur les Mac.

6

pageX

Pour les événements de souris, spécifie la coordonnée horizontale de l'événement par rapport à l'origine de la page.

sept

pageY

Pour les événements de souris, spécifie la coordonnée verticale de l'événement par rapport à l'origine de la page.

8

relatedTarget

Pour certains événements de souris, identifie l'élément que le curseur a laissé ou entré lorsque l'événement a été déclenché.

9

screenX

Pour les événements de souris, spécifie la coordonnée horizontale de l'événement par rapport à l'origine de l'écran.

dix

screenY

Pour les événements de souris, spécifie la coordonnée verticale de l'événement par rapport à l'origine de l'écran.

11

shiftKey

Défini sur true si la touche Shift a été enfoncée lorsque l'événement a été déclenché, false dans le cas contraire.

12

target

Identifie l'élément pour lequel l'événement a été déclenché.

13

timeStamp

L'horodatage (en millisecondes) de la création de l'événement.

14

type

Pour tous les événements, spécifie le type d'événement qui a été déclenché (par exemple, un clic).

15

which

Pour les événements de clavier, spécifie le code numérique de la touche qui a provoqué l'événement, et pour les événements de souris, spécifie le bouton qui a été enfoncé (1 pour la gauche, 2 pour le milieu, 3 pour la droite).

<html>
   <head>
      <title>The jQuery Example</title>
      <script type = "text/javascript" 
         src = "https://ajax.googleapis.com/ajax/libs/jquery/2.1.3/jquery.min.js">
      </script>
		
      <script type = "text/javascript" language = "javascript">
         $(document).ready(function() {
            $('div').bind('click', function( event ){
               alert('Event type is ' + event.type);
               alert('pageX : ' + event.pageX);
               alert('pageY : ' + event.pageY);
               alert('Target : ' + event.target.innerHTML);
            });
         });
      </script>
		
      <style>
         .div{ margin:10px;padding:12px; border:2px solid #666; width:60px;}
      </style>
   </head>
	
   <body>
      <p>Click on any square below to see the result:</p>
		
      <div class = "div" style = "background-color:blue;">ONE</div>
      <div class = "div" style = "background-color:green;">TWO</div>
      <div class = "div" style = "background-color:red;">THREE</div>
   </body>
</html>

Cela produira le résultat suivant -

Les méthodes d'événement

Il existe une liste de méthodes qui peuvent être appelées sur un objet événement -

N ° Sr. Méthode et description
1 preventDefault ()

Empêche le navigateur d'exécuter l'action par défaut.

2 isDefaultPrevented ()

Renvoie si event.preventDefault () a déjà été appelé sur cet objet événement.

3 stopPropagation ()

Arrête la diffusion d'un événement vers les éléments parents, empêchant ainsi les gestionnaires parents d'être notifiés de l'événement.

4 isPropagationStopped ()

Renvoie si event.stopPropagation () a été appelée sur cet objet événement.

5 stopImmediatePropagation ()

Arrête l'exécution du reste des gestionnaires.

6 isImmediatePropagationStopped ()

Renvoie si event.stopImmediatePropagation () a été appelée sur cet objet événement.

Méthodes de manipulation d'événements

Le tableau suivant répertorie les méthodes importantes liées aux événements -

N ° Sr. Méthode et description
1 bind (type, [données], fn)

Lie un gestionnaire à un ou plusieurs événements (comme un clic) pour chaque élément correspondant. Peut également lier des événements personnalisés.

2 off (events [, selector] [, handler (eventObject)])

Cela fait le contraire du live, cela supprime un événement live lié.

3 survoler (au-dessus, en dehors)

Simule le survol, par exemple en déplaçant la souris sur et en dehors d'un objet.

4 on (événements [, sélecteur] [, données], gestionnaire)

Lie un gestionnaire à un événement (comme click) pour tous les éléments correspondants actuels et futurs. Peut également lier des événements personnalisés.

5 un (type, [données], fn)

Lie un gestionnaire à un ou plusieurs événements à exécuter une fois pour chaque élément correspondant.

6 prêt (fn)

Lie une fonction à exécuter chaque fois que le DOM est prêt à être parcouru et manipulé.

sept déclencheur (événement, [données])

Déclenchez un événement sur chaque élément correspondant.

8 triggerHandler (événement, [données])

Déclenche tous les gestionnaires d'événements liés sur un élément.

9 unbind ([type], [fn])

Cela fait le contraire de bind, il supprime les événements liés de chacun des éléments correspondants.

Méthodes d'assistance d'événement

jQuery fournit également un ensemble de fonctions d'assistance d'événement qui peuvent être utilisées soit pour déclencher un événement pour lier tous les types d'événements mentionnés ci-dessus.

Méthodes de déclenchement

Voici un exemple qui déclencherait l'événement de flou sur tous les paragraphes -

$("p").blur();

Méthodes de liaison

Voici un exemple qui lierait un click événement sur tous les <div> -

$("div").click( function () { 
   // do something here
});
N ° Sr. Méthode et description
1

blur( )

Déclenche l'événement de flou de chaque élément correspondant.

2

blur( fn )

Liez une fonction à l'événement de flou de chaque élément correspondant.

3

change( )

Déclenche l'événement de modification de chaque élément correspondant.

4

change( fn )

Lie une fonction à l'événement de modification de chaque élément correspondant.

5

click( )

Déclenche l'événement de clic de chaque élément correspondant.

6

click( fn )

Lie une fonction à l'événement click de chaque élément correspondant.

sept

dblclick( )

Déclenche l'événement dblclick de chaque élément correspondant.

8

dblclick( fn )

Lie une fonction à l'événement dblclick de chaque élément correspondant.

9

error( )

Déclenche l'événement d'erreur de chaque élément correspondant.

dix

error( fn )

Lie une fonction à l'événement d'erreur de chaque élément correspondant.

11

focus( )

Déclenche l'événement de focus de chaque élément correspondant.

12

focus( fn )

Lie une fonction à l'événement de focus de chaque élément correspondant.

13

keydown( )

Déclenche l'événement keydown de chaque élément correspondant.

14

keydown( fn )

Liez une fonction à l'événement keydown de chaque élément correspondant.

15

keypress( )

Déclenche l'événement keypress de chaque élément correspondant.

16

keypress( fn )

Lie une fonction à l'événement keypress de chaque élément correspondant.

17

keyup( )

Déclenche l'événement keyup de chaque élément correspondant.

18

keyup( fn )

Liez une fonction à l'événement keyup de chaque élément correspondant.

19

load( fn )

Lie une fonction à l'événement load de chaque élément correspondant.

20

mousedown( fn )

Lie une fonction à l'événement mousedown de chaque élément correspondant.

21

mouseenter( fn )

Liez une fonction à l'événement mouseenter de chaque élément correspondant.

22

mouseleave( fn )

Liez une fonction à l'événement mouseleave de chaque élément correspondant.

23

mousemove( fn )

Liez une fonction à l'événement mousemove de chaque élément correspondant.

24

mouseout( fn )

Liez une fonction à l'événement mouseout de chaque élément correspondant.

25

mouseover( fn )

Liez une fonction à l'événement mouseover de chaque élément correspondant.

26

mouseup( fn )

Liez une fonction à l'événement mouseup de chaque élément correspondant.

27

resize( fn )

Liez une fonction à l'événement resize de chaque élément correspondant.

28

scroll( fn )

Liez une fonction à l'événement de défilement de chaque élément correspondant.

29

select( )

Déclenchez l'événement de sélection de chaque élément correspondant.

30

select( fn )

Liez une fonction à l'événement select de chaque élément correspondant.

31

submit( )

Déclenchez l'événement de soumission de chaque élément correspondant.

32

submit( fn )

Liez une fonction à l'événement submit de chaque élément correspondant.

33

unload( fn )

Lie une fonction à l'événement de déchargement de chaque élément correspondant.