My.Forms, objet
Fournit des propriétés permettant d'accéder à une instance de chaque formulaire Windows déclaré dans le projet actuel.
Notes
L'objet My.Forms fournit une instance de chaque formulaire dans le projet actuel. La propriété porte le même que celui du formulaire auquel la propriété accède. Pour plus d'informations sur l'ajout de formulaires à un projet, consultez Comment : ajouter des Windows Forms à un projet.
Vous pouvez accéder aux formulaires fournis par l'objet My.Forms à l'aide du nom du formulaire, sans qualification. Étant donné que la propriété porte le même nom que le nom de type du formulaire, vous pouvez accéder à un formulaire comme s'il avait une instance par défaut. Par exemple, My.Forms.Form1.Show est équivalent à Form1.Show.
L'objet My.Forms n'expose que les formulaires associés au projet actuel. Il ne fournit pas un accès aux formulaires déclarés dans les DLL référencées. Pour accéder à un formulaire fourni par une DLL, vous devez utiliser le nom qualifié du formulaire, écrit sous la forme DllName.FormName.
Vous pouvez utiliser la propriété OpenForms pour obtenir une collection de tous les formulaires ouverts de l'application.
L'objet et ses propriétés ne sont disponibles que pour les applications Windows.
Propriétés
Chaque propriété de l'objet My.Forms fournit l'accès à une instance d'un formulaire du projet actuel. La propriété porte le même nom que celui du formulaire auquel accède la propriété et le type de propriété porte le même nom que le type de formulaire.
Notes
Si une collision de noms se produit, le nom de la propriété pour accéder à un formulaire est RootNamespace_Namespace_FormName.Par exemple, prenons deux formulaires nommés Form1.Si l'un de ces formulaires se trouve dans l'espace de noms racine WindowsApplication1 et dans l'espace de noms Namespace1, vous accédez à ce formulaire via My.Forms.WindowsApplication1_Namespace1_Form1.
L'objet My.Forms fournit un accès à l'instance du formulaire principal de l'application qui a été créé au démarrage. Pour tous les autres formulaires, l'objet My.Forms crée une instance du formulaire lorsqu'il est ouvert et le stocke. Les tentatives ultérieures pour accéder à la propriété retournent cette instance du formulaire.
Vous pouvez supprimer un formulaire en assignant Nothing à sa propriété. L'accesseur Set de la propriété appelle la méthode Close du formulaire, puis assigne Nothing à la valeur stockée. Si vous assignez une valeur autre que Nothing à la propriété, l'accesseur Set lève une exception ArgumentException.
Vous pouvez tester si une propriété de l'objet My.Forms stocke une instance du formulaire à l'aide de l'opérateur Is ou IsNot. Vous pouvez utiliser ces opérateurs pour vérifier si la propriété a la valeur Nothing.
Notes
En général, l'opérateur Is ou IsNot doit lire la valeur de la propriété pour effectuer la comparaison.Toutefois, si la propriété stocke actuellement Nothing, la propriété crée une instance du formulaire, puis la retourne.Néanmoins, le compilateur Visual Basic traite différemment les propriétés de l'objet My.Forms et permet à l'opérateur Is ou IsNot de vérifier l'état de la propriété sans modifier sa valeur.
Exemple
Cet exemple modifie le titre du formulaire SidebarMenu par défaut.
Sub ShowSidebarMenu(ByVal newTitle As String)
If My.Forms.SidebarMenu IsNot Nothing Then
My.Forms.SidebarMenu.Text = newTitle
End If
End Sub
Pour que cet exemple fonctionne, votre projet doit avoir un formulaire nommé SidebarMenu. Pour plus d'informations, consultez Comment : ajouter des Windows Forms à un projet.
Ce code ne fonctionne que dans un projet d'application Windows.
Configuration requise
Disponibilité par type de projet
Type de projet |
Disponible |
Application Windows |
Oui |
Bibliothèque de classes |
Non |
Application console |
Non |
Bibliothèque de contrôles Windows |
Non |
Bibliothèque de contrôles Web |
Non |
Service Windows |
Non |
Site Web |
Non |
Voir aussi
Tâches
Comment : ajouter des Windows Forms à un projet
Référence
Opérateur IsNot (Visual Basic)