IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

VB 6 et antérieur Discussion :

[Appel de Formulaire] : Débutant


Sujet :

VB 6 et antérieur

  1. #1
    Membre du Club
    Homme Profil pro
    Architecte technique
    Inscrit en
    Juillet 2002
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2002
    Messages : 52
    Points : 44
    Points
    44
    Par défaut [Appel de Formulaire] : Débutant
    Bonjour,

    Je souhaiterais appeller un formulaire depuis un autre proprement

    J'ai un formulaire Form1 avec un CommandButton1
    et je veux appeller mon formulaire Form2 et un InputText2 à initialiser

    Dois-je faire :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    Private Sub Command1_Click()
         Form2.Text1.Text = "40.0000"
         Form2.Show
    End Sub
    ou bien
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    Private Sub Command1_Click()
       Dim formx As New Form2
       formx.Text2 = "40.000"
       formx.Show
    End Sub
    Merci de votre aide.

  2. #2
    Rédacteur
    Avatar de DarkVader
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Mai 2002
    Messages
    2 130
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Mai 2002
    Messages : 2 130
    Points : 3 118
    Points
    3 118
    Par défaut
    Citation Envoyé par lucimast Voir le message
    Bonjour,

    Je souhaiterais appeller un formulaire depuis un autre proprement

    J'ai un formulaire Form1 avec un CommandButton1
    et je veux appeller mon formulaire Form2 et un InputText2 à initialiser

    Dois-je faire :

    Private Sub Command1_Click()
    Form2.Text1.Text = "40.0000"
    Form2.Show
    End Sub

    ou bien

    Private Sub Command1_Click()
    Dim formx As New Form2
    formx.Text2 = "40.000"
    formx.Show
    End Sub

    Merci de votre aide.
    Bonjour,
    Les feuilles (form) sont des classes préinstanciées, il n'est donc pas nécessaire dans ce contexte
    de créer une nouvelle instance dont l'intérêt serait d'isoler des données

    ex avec 2 formulaires (form1, form2) de l'isolation des données avec 2 instances d'un même formulaire
    Form1+2 CommandButton(Command1/Command2)
    Form2+1 TextBox(Text1)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    Private frm0 As Form2
    Private frm1 As Form2
     
    Private Sub Command1_Click()
        Me.Print frm0.Text1
    End Sub
     
    Private Sub Command2_Click()
        Me.Print frm1.Text1
    End Sub
     
    Private Sub Form_Load()
        Set frm0 = New Form2
        Set frm1 = New Form2
        frm1.Left = frm0.Left + frm0.Width
        frm0.Text1 = "abc"
        frm1.Text1 = "123"
        frm0.Show
        frm1.Show
    End Sub
     
    Private Sub Form_Unload(Cancel As Integer)
        Unload frm0
        Unload frm1
    End Sub
    Il existe une solution qui me semble plus 'esthétique' et fonctionnelle que celle envisagée
    quand il s'agit de créer un outil personnalisé à partir d'un formulaire et qui consiste
    - à appeler une fonction d'un formulaire et
    - à gérer l'affichage depuis le formulaire lui-même sachant que Form_Load sera appelé après l'appel de la fonction permettant ainsi de gérer automatiquement toutes les mises en forme

    ex
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    Public Function Saisie(prompt As String) As String
        Me.Text1.Text = prompt
        Me.Show 1
     
        Saisie = Me.Text1.Text
    End Function
     
    Private Sub Form_Load()
        With Me.Text1
            .Left = 100
           .Top = 100
           .Width = 5000
     
            Me.Width = .Left + .Width + 1500
            Me.Height = .Top + .Height + 1500
        End With
     
        'etc
    End Sub
    l'appel se fera par exemple ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    msgbox form2.Saisie("un texte")
    Ceci dit, dans le cas présent un InputBox devrait suffire.

  3. #3
    Membre du Club
    Homme Profil pro
    Architecte technique
    Inscrit en
    Juillet 2002
    Messages
    52
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Architecte technique
    Secteur : Industrie

    Informations forums :
    Inscription : Juillet 2002
    Messages : 52
    Points : 44
    Points
    44
    Par défaut
    Merci c'est très clair!

Discussions similaires

  1. Réponses: 5
    Dernier message: 21/12/2006, 18h19
  2. appel sous-formulaire et retour avec ecran normal
    Par pat1545 dans le forum Access
    Réponses: 1
    Dernier message: 31/07/2006, 19h18
  3. problème de mise en page de formulaire (débutante)
    Par emmablue dans le forum Access
    Réponses: 2
    Dernier message: 21/07/2006, 12h26
  4. [VBA-A]appeler un formulaire existant
    Par eultartuffe dans le forum VBA Access
    Réponses: 2
    Dernier message: 01/05/2006, 22h32
  5. [VB.Net]Comment appeler un formulaire ?
    Par Paolo21 dans le forum Windows Forms
    Réponses: 2
    Dernier message: 20/03/2006, 19h27

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo