Événements (Visual Basic)
Vous pouvez comparer un projet Visual Studio à une série de procédures qui s'exécutent dans une séquence, mais en réalité, la plupart des programmes sont pilotés par des événements, c'est-à-dire que le déroulement de l'exécution dépend d'occurrences externes appelées événements.
Un événement est un signal qui informe l'application que quelque chose d'important s'est produit.Par exemple, lorsqu'un utilisateur clique sur un contrôle d'un formulaire, le formulaire peut déclencher un événement Click et appeler une procédure qui gère l'événement.Les événements séparent également les tâches pour communiquer.Supposons, par exemple, que votre application exécute une tâche de tri séparément de l'application principale.Si un utilisateur annule le tri, votre application peut envoyer un événement d'annulation demandant au processus de tri de s'interrompre.
Termes et concepts relatifs aux événements
Cette section décrit les termes et concepts utilisés avec les événements en Visual Basic.
Déclaration d'événements
Vous déclarez des événements dans le cadre de classes, structures, modules et interfaces à l'aide du mot clé Event, comme dans l'exemple suivant :
Event AnEvent(ByVal EventNumber As Integer)
Déclenchement d'événements
Un événement est comparable à un message annonçant que quelque chose d'important s'est produit.L'acte de diffusion du message est appelé déclenchement de l'événement.En Visual Basic, vous déclenchez des événements à l'aide de l'instruction RaiseEvent, comme dans l'exemple suivant :
RaiseEvent AnEvent(EventNumber)
Les événements doivent être déclenchés dans la portée de la classe, du module ou de la structure où ils sont déclarés.Par exemple, une classe dérivée ne peut pas déclencher d'événements hérités à partir d'une classe de base.
Émetteurs d'événements
Tout objet capable de déclencher un événement est un émetteur d'événements, également appelé source d'événements.Les formulaires, contrôles et objets définis par l'utilisateur sont des exemples d'émetteurs d'événements.
Gestionnaires d'événements
Les gestionnaires d'événements sont des procédures appelées lorsqu'un événement correspondant se produit.Vous pouvez utiliser n'importe quelle sous-routine valide avec une signature correspondante comme gestionnaire d'événements.Il vous est cependant impossible d'utiliser une fonction en tant que gestionnaire d'événements parce qu'une fonction ne peut retourner une valeur à la source des événements.
Visual Basic utilise pour les gestionnaires d'événements une convention d'affectation de noms standard qui combine le nom de l'émetteur de l'événement, un trait de soulignement et le nom de l'événement.Par exemple, l'événement Click d'un bouton appelé button1 aurait pour nom Sub button1_Click.
[!REMARQUE]
Nous vous recommandons, mais ce n'est pas obligatoire, d'utiliser cette convention d'affectation de noms lorsque vous définissez des gestionnaires d'événements pour vos propres événements ; vous pouvez utiliser n'importe quel nom de sous-routine valide.
Association d'événements aux gestionnaires d'événements
Avant de pouvoir utiliser un gestionnaire d'événements, vous devez au préalable l'associer à un événement à l'aide de l'instruction Handles ou AddHandler.
WithEvents et la clause Handles
L'instruction WithEvents et la clause Handles assurent une méthode déclarative de spécification des gestionnaires d'événements.Un événement déclenché par un objet déclaré par le mot clé WithEvents peut être géré par n'importe quelle procédure avec une instruction Handles pour cet événement, comme le montre l'exemple suivant :
' Declare a WithEvents variable.
Dim WithEvents EClass As New EventClass
' Call the method that raises the object's events.
Sub TestEvents()
EClass.RaiseEvents()
End Sub
' Declare an event handler that handles multiple events.
Sub EClass_EventHandler() Handles EClass.XEvent, EClass.YEvent
MsgBox("Received Event.")
End Sub
Class EventClass
Public Event XEvent()
Public Event YEvent()
' RaiseEvents raises both events.
Sub RaiseEvents()
RaiseEvent XEvent()
RaiseEvent YEvent()
End Sub
End Class
L'instruction WithEvents et la clause Handles représentent souvent la meilleure solution pour les gestionnaires d'événements, parce que la syntaxe déclarative qu'ils utilisent simplifie beaucoup le codage, la lecture et le débogage de la gestion des événements.Il faut cependant garder à l'esprit les restrictions liées à l'utilisation des variables WithEvents :
Vous ne pouvez pas utiliser une variable WithEvents comme variable d'objet.Cela signifie que vous ne pouvez pas la déclarer en tant que Object ; vous devez spécifier le nom de la classe lorsque vous déclarez la variable.
Les événements partagés n'étant pas associés à des instances de classe, vous ne pouvez pas utiliser WithEvents pour les gérer de façon déclarative.De même, vous ne pouvez pas utiliser WithEvents ou Handles pour gérer les événements de Structure.Dans les deux cas, vous pouvez utiliser l'instruction AddHandler pour gérer ces événements.
Vous ne pouvez pas créer de tableaux de variables WithEvents.
Les variables WithEvents autorisent un seul gestionnaire d'événements à gérer un ou plusieurs types d'événements ou un ou plusieurs gestionnaires d'événements à gérer le même type d'événements.
Même si la clause Handles constitue la méthode standard d'association d'un événement à un gestionnaire d'événements, son action est restreinte à l'association d'événements aux gestionnaires d'événements au moment de la compilation.
Dans certains cas (par exemple, avec des événements associés à des formulaires ou des contrôles), Visual Basic définit automatiquement un gestionnaire d'événements vide et l'associe à un événement.Par exemple, lorsque vous double-cliquez sur un bouton de commande dans un formulaire en mode design, Visual Basic crée un gestionnaire d'événements vide et une variable WithEvents pour le bouton de commande, comme dans le code suivant :
Friend WithEvents Button1 As System.Windows.Forms.Button
Protected Sub Button1_Click() Handles Button1.Click
End Sub
AddHandler et RemoveHandler
L'instruction AddHandler est comparable à la clause Handles dans la mesure où toutes deux vous permettent de spécifier un gestionnaire d'événements.Cependant, AddHandler utilisé conjointement avec RemoveHandler, offre une plus grande souplesse que la clause Handles ; ils vous permettent d'ajouter, de supprimer et de changer dynamiquement le gestionnaire d'événements associé à un événement.Si vous souhaitez gérer des événements partagés ou des événements d'une structure, vous devez utiliser AddHandler.
AddHandler prend en compte deux arguments : le nom d'un événement issu d'un émetteur d'événements tel qu'un contrôle et une expression qui a pour valeur un délégué.Comme l'instruction AddressOf retourne toujours une référence au délégué, vous n'êtes pas obligé de spécifier explicitement la classe déléguée lorsque vous utilisez AddHandler.L'exemple ci-dessous associe un gestionnaire d'événements à un événement déclenché par un objet :
AddHandler Obj.XEvent, AddressOf Me.XEventHandler
RemoveHandler, qui déconnecte un événement d'un gestionnaire d'événements, utilise la même syntaxe que AddHandler.Par exemple :
RemoveHandler Obj.XEvent, AddressOf Me.XEventHandler
Dans l'exemple suivant, un gestionnaire d'événements est associé à un événement et cet événement est déclenché.Le gestionnaire d'événements intercepte l'événement et affiche un message.
Le premier gestionnaire d'événements est ensuite supprimé et un autre gestionnaire d'événements est associé à l'événement.Lorsque l'événement est de nouveau déclenché, un autre message s'affiche.
Enfin, le second gestionnaire d'événements est supprimé et l'événement est déclenché pour la troisième fois.Étant donné qu'aucun gestionnaire d'événements n'est désormais associé à l'événement, aucune action n'est effectuée.
Module Module1
Sub Main()
Dim c1 As New Class1
' Associate an event handler with an event.
AddHandler c1.AnEvent, AddressOf EventHandler1
' Call a method to raise the event.
c1.CauseTheEvent()
' Stop handling the event.
RemoveHandler c1.AnEvent, AddressOf EventHandler1
' Now associate a different event handler with the event.
AddHandler c1.AnEvent, AddressOf EventHandler2
' Call a method to raise the event.
c1.CauseTheEvent()
' Stop handling the event.
RemoveHandler c1.AnEvent, AddressOf EventHandler2
' This event will not be handled.
c1.CauseTheEvent()
End Sub
Sub EventHandler1()
' Handle the event.
MsgBox("EventHandler1 caught event.")
End Sub
Sub EventHandler2()
' Handle the event.
MsgBox("EventHandler2 caught event.")
End Sub
Public Class Class1
' Declare an event.
Public Event AnEvent()
Sub CauseTheEvent()
' Raise an event.
RaiseEvent AnEvent()
End Sub
End Class
End Module
Gestion d'événements hérités d'une classe de base
Les Classes dérivées, classes qui héritent des caractéristiques d'une classe de base, peuvent gérer des événements déclenchés par leur classe de base à l'aide de l'instruction HandlesMyBase.
Pour gérer les événements d'une classe de base
Déclarez un gestionnaire d'événements dans la classe dérivée en ajoutant une instruction Handles MyBase.NomÉvénement à la ligne de déclaration de votre procédure gestionnaire d'événements, où NomÉvénement est le nom de l'événement dans la classe de base gérée.Par exemple :
Public Class BaseClass Public Event BaseEvent(ByVal i As Integer) ' Place methods and properties here. End Class Public Class DerivedClass Inherits BaseClass Sub EventHandler(ByVal x As Integer) Handles MyBase.BaseEvent ' Place code to handle events from BaseClass here. End Sub End Class
Rubriques connexes
Titre |
Description |
---|---|
Procédure pas à pas : déclaration et déclenchement des événements (Visual Basic) |
Fournit une description pas à pas de la déclaration et du déclenchement des événements pour une classe. |
Montre comment écrire une procédure gestionnaire d'événements. |
|
Comment : déclarer des événements personnalisés pour éviter les blocages (Visual Basic) |
Montre comment définir un événement personnalisé qui autorise l'appel asynchrone de ses gestionnaires d'événements. |
Comment : déclarer des événements personnalisés pour économiser la mémoire (Visual Basic) |
Montre comment définir un événement personnalisé qui utilise la mémoire uniquement lorsque l'événement est géré. |
Dépannage des gestionnaires d'événements hérités dans Visual Basic |
Répertorie les problèmes courants liés aux gestionnaires d'événements dans les composants hérités. |
Propose une vue d'ensemble du modèle d'événement dans le .NET Framework. |
|
Création de gestionnaires d'événements dans les Windows Forms |
Décrit comment utiliser des événements associés aux objets Windows Forms. |
Fournit une vue d'ensemble de délégués dans Visual Basic. |