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. |