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

IHM Discussion :

Ajouter en VBA une astérisque aux champs obligatoires dans un formulaire [AC-2003]


Sujet :

IHM

  1. #1
    Membre averti
    Homme Profil pro
    Amateur
    Inscrit en
    Octobre 2010
    Messages
    205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Amateur

    Informations forums :
    Inscription : Octobre 2010
    Messages : 205
    Points : 360
    Points
    360
    Par défaut Ajouter en VBA une astérisque aux champs obligatoires dans un formulaire
    Bonjour,

    J'en avais marre de mettre manuellement des astérisques à côté des champs obligatoires dans un formulaire, j'ai donc écrit cette fonction. Cependant, elle génère une erreur à la ligne 50 sur "ctrlX.Parent", erreur de type à priori. Quelqu'un à une idée ?

    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
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
     
    Public Sub AjouteAsterisque(ByVal FormulaireCible As String)
        Dim recX As Recordset, formX As Form, ctrlX As Control, fieldX As Field, NewLabel As Control
        Dim blSuppr As Boolean
     
        DoCmd.OpenForm FormulaireCible, acDesign    'Ouverture du formulaire en mode création
        Set formX = Application.Forms(FormulaireCible)    'Affectation du formulaire à la variable formX
     
        'Vérifions d'abord si le formulaire est lié à une source de données !
        If formX.RecordSource <> "" Then
            Set recX = CurrentDb.OpenRecordset(formX.RecordSource)
        Else
            Exit Sub    'Le formulaire n'est pas lié, fin de la procédure
        End If
     
        'Suppression des précedentes étiquettes
     
        'On va balayer les contôles (For... Next) et si le nom correspond à une étiquette astérisque alors on le supprime
        'Cependant quand on supprime un contrôle, la collection est modifiée !
        'On va donc boucler avec Do until et refaire le balayage jusqu'à ce qu'il n'y ait plus d'étiquette astérisque
     
        blSuppr = True
        Do Until blSuppr = False
            For Each ctrlX In formX.Controls
                blSuppr = False    'Met l'indicateur à faux
                If Left$(ctrlX.Name, 4) = "ast_" Then    'si le nom du contôle comme par...
                    DeleteControl FormulaireCible, ctrlX.Name    'Suppression du contrôle
                    blSuppr = True    'Met l'indicateur à Vrai
                End If
            Next ctrlX
        Loop
     
        'Création des étiquettes.
        'On balaye tous les contôles For...Next
        'On ne prend en compte que les contrôles Textbox et combobox
        'On récupère le champ lié, puis on vérifie si le champ doit être renseigné (propriéts Required et AllowZeroLength
     
        For Each ctrlX In formX.Controls    'balaye tous les contôles du formulaire
            'Debug.Print TypeName(ctrlX)
            If TypeName(ctrlX) = "Textbox" Or TypeName(ctrlX) = "Combobox" Then
     
                If ctrlX.ControlSource <> "" Then    'le contrôle est lieu à un champ
     
                    Set fieldX = recX.Fields(ctrlX.ControlSource)    'Affectation du champ à la variable fieldX
                    If Not fieldX.AllowZeroLength Or fieldX.Required Then    'Le champ doit être différent de Null ou la chaine ne peut être vide
     
                        'Création de l'étiquette, les coordonnées sont en fonction du contrôle "source"
                        'La propriété ctrlX.Parent permet de récupérer le conteneur (par exemple un onglet)
     
                        Set NewLabel = CreateControl(FormulaireCible, acLabel, , ctrlX.Parent, , _
                                                     ctrlX.Left + ctrlX.Width + 60, ctrlX.Top - 45, 250, 250)
     
                        NewLabel.Name = "ast_" & ctrlX.Name    'le nom de l'éatiquette reprend le nom du contôle
                        NewLabel.Caption = "*"    'Met une astérisque (ou ce qu'on veut !)
                        NewLabel.FontName = "MS Sans Serif"    'Police MS Sans Serif (ou ce qu'on veut)
                        NewLabel.FontSize = 14    'Taille de police
                        NewLabel.ForeColor = vbRed    'En rouge
     
                    End If
     
                End If
     
     
            End If
     
        Next ctrlX
     
        Exit Sub
     
    Err_Gest:
        Resume Next
     
     
    End Sub
    Pierre.

    Dans un monde passablement absurde, il y a quelque chose qui ne l'est pas, c'est ce qu'on peut faire pour les autres.

    André Malraux


    Ce message vous a aidé ? alors

    Votre souci est résolu ? alors

  2. #2
    Membre averti
    Homme Profil pro
    Amateur
    Inscrit en
    Octobre 2010
    Messages
    205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Amateur

    Informations forums :
    Inscription : Octobre 2010
    Messages : 205
    Points : 360
    Points
    360
    Par défaut [résolu]
    Bon, je me répond à moi-même. Evidemment on cherche une heure et juste après avoir posté, on trouve la réponse. Au lieu de ctrlX.Parent, il faut mettre ctrlX.Parent.Name.

    Ce qui donne :

    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
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
     
    Public Sub AjouteAsterisque(ByVal FormulaireCible As String)
        Dim recX As Recordset, formX As Form, ctrlX As Control, fieldX As Field, NewLabel As Control
        Dim blSuppr As Boolean
     
        DoCmd.OpenForm FormulaireCible, acDesign    'Ouverture du formulaire en mode création
        Set formX = Application.Forms(FormulaireCible)    'Affectation du formulaire à la variable formX
     
        'Vérifions d'abord si le formulaire est lié à une source de données !
        If formX.RecordSource <> "" Then
            Set recX = CurrentDb.OpenRecordset(formX.RecordSource)
        Else
            Exit Sub    'Le formulaire n'est pas lié, fin de la procédure
        End If
     
        'Suppression des précedentes étiquettes
     
        'On va balayer les contôles (For... Next) et si le nom correspond à une étiquette astérisque alors on le supprime
        'Cependant quand on supprime un contrôle, la collection est modifiée !
        'On va donc boucler avec Do until et refaire le balayage jusqu'à ce qu'il n'y ait plus d'étiquette astérisque
     
        blSuppr = True
        Do Until blSuppr = False
            For Each ctrlX In formX.Controls
                blSuppr = False    'Met l'indicateur à faux
                If Left$(ctrlX.Name, 4) = "ast_" Then    'si le nom du contôle comme par...
                    DeleteControl FormulaireCible, ctrlX.Name    'Suppression du contrôle
                    blSuppr = True    'Met l'indicateur à Vrai
                End If
            Next ctrlX
        Loop
     
        'Création des étiquettes.
        'On balaye tous les contôles For...Next
        'On ne prend en compte que les contrôles Textbox et combobox
        'On récupère le champ lié, puis on vérifie si le champ doit être renseigné (propriéts Required et AllowZeroLength
     
        For Each ctrlX In formX.Controls    'balaye tous les contôles du formulaire
            'Debug.Print TypeName(ctrlX)
            If TypeName(ctrlX) = "Textbox" Or TypeName(ctrlX) = "Combobox" Then
     
                If ctrlX.ControlSource <> "" Then    'le contrôle est lieu à un champ
     
                    Set fieldX = recX.Fields(ctrlX.ControlSource)    'Affectation du champ à la variable fieldX
                    If Not fieldX.AllowZeroLength Or fieldX.Required Then    'Le champ doit être différent de Null ou la chaine ne peut être vide
     
                        'Création de l'étiquette, les coordonnées sont en fonction du contrôle "source"
                        'La propriété ctrlX.Parent.name permet de récupérer le conteneur (par exemple un onglet)
     
                        Set NewLabel = CreateControl(FormulaireCible, acLabel, , ctrlX.Parent.Name, , _
                                                     ctrlX.Left + ctrlX.Width + 60, ctrlX.Top - 45, 250, 250)
     
                        NewLabel.Name = "ast_" & ctrlX.Name    'le nom de l'éatiquette reprend le nom du contôle
                        NewLabel.Caption = "*"    'Met une astérisque (ou ce qu'on veut !)
                        NewLabel.FontName = "MS Sans Serif"    'Police MS Sans Serif (ou ce qu'on veut)
                        NewLabel.FontSize = 14    'Taille de police
                        NewLabel.ForeColor = vbRed    'En rouge
     
                    End If
     
                End If
     
     
            End If
     
        Next ctrlX
     
        Exit Sub
     
    Err_Gest:
        Resume Next
     
     
    End Sub
    Pierre.

    Dans un monde passablement absurde, il y a quelque chose qui ne l'est pas, c'est ce qu'on peut faire pour les autres.

    André Malraux


    Ce message vous a aidé ? alors

    Votre souci est résolu ? alors

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

Discussions similaires

  1. champs obligatoire dans un formulaire access 2007
    Par mimi2030 dans le forum IHM
    Réponses: 1
    Dernier message: 06/07/2011, 13h32
  2. [AC-2000] comparaison champ d'une table et champ saisi dans un formulaire
    Par guaguanco dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 06/09/2010, 15h39
  3. Positionnement d'un champs obligatoires dans un formulaire de contact
    Par sofiane06 dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 10/08/2010, 12h13
  4. Champs obligatoires dans un formulaire
    Par sagitarium dans le forum Balisage (X)HTML et validation W3C
    Réponses: 12
    Dernier message: 23/05/2006, 16h55
  5. Champs obligatoires dans un formulaire
    Par glloq8 dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 30/09/2005, 16h24

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