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

VBA Access Discussion :

Vérifier si un formulaire est ouvert


Sujet :

VBA Access

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 300
    Points : 106
    Points
    106
    Par défaut Vérifier si un formulaire est ouvert
    Bonjour,

    Sur la propriété "sur fermeture" d'un formulaire j'actualise un autre formulaire ouvert derrière, mais comment faire pour vérifier si ce dernier est ouvert pour que la fermeture se passe correctement ?


    Formulaire à actualiser : "saisie"
    Mon code sur fermeture du deuxième
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Me.forms!saisie!liste.requery
    On peut faire plus simple ?

    Merci

  2. #2
    Membre chevronné
    Inscrit en
    Août 2006
    Messages
    1 588
    Détails du profil
    Informations forums :
    Inscription : Août 2006
    Messages : 1 588
    Points : 2 178
    Points
    2 178
    Par défaut
    pour ma part j'utilise ce code
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    Function EstOuvertForm(NomForm As String) As Boolean
        On Error GoTo erreur
        EstOuvertForm = False
        If Forms(NomForm ).Name = NomForm  Then EstOuvertForm = True
        Exit Function
    erreur:
    End Function
    donc

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
     If EstOuvertForm("NomDuFormulaire") Then Forms("NomDuFormulaire").Requery

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 300
    Points : 106
    Points
    106
    Par défaut
    Merci Helas,

    Le code qui commence par Function EstOuvertForm(NomForm As String) As Boolean


    je dois le mettre dans un nouveau module ?

    Et le deuxième je le colle ou ?

    Merci.

  4. #4
    Membre expérimenté Avatar de stigma
    Homme Profil pro
    Créateur jeux vidéo
    Inscrit en
    Octobre 2003
    Messages
    1 115
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : France, Pas de Calais (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Créateur jeux vidéo
    Secteur : Arts - Culture

    Informations forums :
    Inscription : Octobre 2003
    Messages : 1 115
    Points : 1 616
    Points
    1 616
    Par défaut
    Voici le code que j'utilise :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Public Function IsLoaded(ByVal chNomForm As String) As Boolean
     
        '---------------------------  Renvoie Vrai si le formulaire spécifié est chargé.
        Const conModeCréation = 0
        Const conEtatObjFermé = 0
        IsLoaded = False
        If SysCmd(acSysCmdGetObjectState, acForm, chNomForm) <> conEtatObjFermé Then
            If Forms(chNomForm).CurrentView <> conModeCréation Then IsLoaded = True
        End If
     
    End Function
    je le mets dans un module quelconque genre "Fonctions diverses"

    puis j'appelle par
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
        If IsLoaded("F_Fiches") = True Then DoCmd.Close acForm, "F_Fiches"

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 300
    Points : 106
    Points
    106
    Par défaut
    Merci pour la réponse

    @+

  6. #6
    Membre expérimenté Avatar de Gabout
    Homme Profil pro
    Utilisateur autodidacte
    Inscrit en
    Mai 2006
    Messages
    1 404
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 69
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Utilisateur autodidacte

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 404
    Points : 1 683
    Points
    1 683
    Par défaut
    Bonjour,

    Autre solution :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    If CurrentProject.AllForms("TonFormulaire").IsLoaded then
      '...
    End if
    A+

  7. #7
    Membre régulier
    Homme Profil pro
    Inscrit en
    Mars 2008
    Messages
    127
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 64
    Localisation : France, Seine Saint Denis (Île de France)

    Informations forums :
    Inscription : Mars 2008
    Messages : 127
    Points : 78
    Points
    78
    Par défaut
    Pour ma part, j'utilise également une autre méthode :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    If ControlExists("Nom du formulaire", "Nom d'un contrôle") Then
        msgbox "Le formulaire est ouvert"
    End If
        msgbox "Le formulaire est fermé"

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2008
    Messages
    300
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2008
    Messages : 300
    Points : 106
    Points
    106
    Par défaut
    Merci à tous.

    @+

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

Discussions similaires

  1. Réponses: 2
    Dernier message: 22/05/2015, 21h55
  2. Réponses: 2
    Dernier message: 20/07/2007, 08h02
  3. Vérifier si un formulaire est ouvert
    Par codial dans le forum Delphi
    Réponses: 2
    Dernier message: 02/03/2007, 15h52
  4. Vérifier qu'un formulaire est ouvert
    Par com800 dans le forum WinDev
    Réponses: 2
    Dernier message: 07/04/2005, 20h27
  5. Vérifier si une form est ouverte
    Par nivet dans le forum Langage
    Réponses: 6
    Dernier message: 23/11/2004, 09h17

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