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

Access Discussion :

Erreur sur OpenArgs


Sujet :

Access

  1. #1
    Membre habitué
    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 78
    Localisation : France, Val d'Oise (Île de France)

    Informations forums :
    Inscription : Août 2005
    Messages : 660
    Points : 165
    Points
    165
    Par défaut Erreur sur OpenArgs
    Bonsoir,

    Mon formulaire1 comprend un contrôle onglet, et sur ce contrôle onglet j’ai un sous formulaire1 en Affichage par défaut « mode continue » avec un contrôle btn1 qui ouvre un formulaire2.

    Je voudrais, lorsque j’ouvre le formulaire2 faire disparaître le formulaire1 et le faire réapparaître lorsque je le ferme.

    Le code ci-dessous me donne une erreur « sous formulaire1 introuvable »

    Code du formulaire2

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Form_Unload(Cancel As Integer)
    '--- Réaffiche le menu
         If IsLoaded("formulaire1") Or IsLoaded("sous formulaire1") Then
            Forms(Nz(Me.OpenArgs)).Visible = True
         End If
    End Sub
    Code du contrôle Btn1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Private Sub btn1_Click()
    On Error GoTo Err_Form_Click
        Dim stDocName As String
        Dim stLinkCriteria As String
        Forms![formulaire1].Visible = False
        StDocName = "formulaire2"
        DoCmd.OpenForm stDocName, , , stLinkCriteria, OpenArgs:=Me.Name
    Exit_Form_Click:
        Exit Sub
    Err_Form_Click:
        MsgBox err.Description
        Resume Exit_Form_Click
    End Sub
    Merci pour votre aide.

    Salutations

  2. #2
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonsoir,

    Essaie d'enlever Or IsLoaded("sous formulaire1").
    Je crois que les sous-formulaires ne sont pas visibles dans la collection Forms.
    On ne peut les voir qu'en tant que contrôle d'un Formulaire ouvert.

    A+

  3. #3
    Membre habitué
    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 78
    Localisation : France, Val d'Oise (Île de France)

    Informations forums :
    Inscription : Août 2005
    Messages : 660
    Points : 165
    Points
    165
    Par défaut
    Re Bonsoir,

    Merci pour ta réponse j'ai essayé le code suivant sans succès.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    Private Sub Form_Unload(Cancel As Integer)
    '--- Réaffiche le menu
         If IsLoaded("formulaire1") Then
            Forms(Nz(Me.OpenArgs)).Visible = True
         End If
    End Sub
    et Me.OpenArgs prend la valeur "sous formulaire1"

    Salutations.

  4. #4
    Expert éminent
    Avatar de LedZeppII
    Homme Profil pro
    Maintenance données produits
    Inscrit en
    Décembre 2005
    Messages
    4 485
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Maintenance données produits
    Secteur : Distribution

    Informations forums :
    Inscription : Décembre 2005
    Messages : 4 485
    Points : 7 759
    Points
    7 759
    Par défaut
    Bonsoir,

    J'avais pas vu le OpenArgs.
    Voila comment on pourrai faire :
    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
    Private Sub btn1_Click()
    On Error GoTo Err_Form_Click
        Dim stDocName As String, stDocAmasquer As String
        Dim stLinkCriteria As String     
        stDocAmasquer = Me.Name  ' Par défaut formulaire contenant ce code
        On Error Resume Next                 ' Ignorer Erreur
           stDocAmasquer = Me.Parent.Name    ' Essaie Formulaire Parent 
        On Error Goto Err_Form_Click          
        Forms(stDocAmasquer ).Visible = False
        StDocName = "formulaire2"
        DoCmd.OpenForm stDocName, , , stLinkCriteria, OpenArgs:=stDocAmasquer 
    Exit_Form_Click:
        Exit Sub
    Err_Form_Click:
        MsgBox err.Description
        Resume Exit_Form_Click
    End Sub
    Pour bien utiliser OpenArgs j'écrirai comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Private Sub Form_Unload(Cancel As Integer)
    '--- Réaffiche le menu
         Dim stDocName As String
         stDocName = Nz(Me.OpenArgs)
         If stDocName <>"" then
            If IsLoaded(stDocName) Then
               Forms(stDocName).Visible = True
            End If
         End If
    End Sub
    Comme ça, quel que soit le formulaire qui ouvre Formulaire2 en donnant son nom dans OpenArgs,
    Formulaire2 essaiera de le rendre visible.

    J'espère que ça répond mieux à ton attente.
    A+

  5. #5
    Membre habitué
    Homme Profil pro
    Inscrit en
    Août 2005
    Messages
    660
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 78
    Localisation : France, Val d'Oise (Île de France)

    Informations forums :
    Inscription : Août 2005
    Messages : 660
    Points : 165
    Points
    165
    Par défaut
    Bonjour LeddZepII.

    Merci pour ta solution elle fonctionne correctement.

    Salutations

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Erreur sur une fonction avec des paramètres
    Par Elois dans le forum PostgreSQL
    Réponses: 2
    Dernier message: 05/05/2004, 21h00
  2. [VBS] Erreur sur "AddWindowsPrinterConnection"
    Par Admin dans le forum VBScript
    Réponses: 5
    Dernier message: 27/03/2004, 16h15
  3. Erreur sur serveur lié
    Par k-lendos dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 18/03/2004, 15h21
  4. []Erreur sur second emploi collection binding
    Par jacma dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 08/03/2004, 18h02
  5. Erreur sur le TNSListener après installation de 9iAS
    Par Patmane dans le forum Installation
    Réponses: 4
    Dernier message: 04/02/2004, 11h16

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