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 Word Discussion :

Rendre obligatoire des champs text d'un formulaire Word [WD-2010]


Sujet :

VBA Word

  1. #1
    Membre régulier
    Femme Profil pro
    Formatrice bureautique
    Inscrit en
    Septembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Formatrice bureautique

    Informations forums :
    Inscription : Septembre 2007
    Messages : 202
    Points : 79
    Points
    79
    Par défaut Rendre obligatoire des champs text d'un formulaire Word
    Hello le forum,

    Je suis en train de sécher depuis 1 heure pour savoir comment je peux rendre obligatoire la saisie de tous les champs d'un formulaire Word.

    J'ai trouvé que sur chaque champ, on peut exécuter une macro à la sortie et j'ai essayé le code suivant. Le test fonctionne lorsque je sors du champ mais Word se place sur le champ suivant alors que je lui dit de sélectionner le champ Nom car je souhaite que si celui-ci n'est pas compléter, il est impossible d'aller au champ suivant.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    Sub ChampsObligatoires()
     
    If ActiveDocument.FormFields("nom").Result = "" Then
     
    MsgBox ("Ce champ doit être complété")
    ActiveDocument.FormFields("nom").Select
    End If
     
    End Sub
    Je pense qu'il doit exister un code spécifique car mon idéal sera que tous les champs soient obligatoires. Est-ce que je peux placer ma macro à l'enregistrement de mon fichier afin que tous les champs soient tester et m'afficher un message si des champs ne sont pas complétés afin que le document ne puisse pas être enregistré ou imprimer si l'ensemble du formulaire n'est pas complété...

    AieAieAie, j'espère être claire ;-) et merci pour vos lumières

  2. #2
    Rédacteur/Modérateur

    Avatar de Heureux-oli
    Homme Profil pro
    Contrôleur d'industrie
    Inscrit en
    Février 2006
    Messages
    21 087
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 59
    Localisation : Belgique

    Informations professionnelles :
    Activité : Contrôleur d'industrie
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Février 2006
    Messages : 21 087
    Points : 42 926
    Points
    42 926
    Par défaut
    Salut,

    Il faut aller à un autre champ pour revenir à celui que l'on vient de quitter.

    Mais ça ne rendra pas ce champ obligatoire, si je n'y passe pas, la macro ne va pas s'exécuter.
    Tu auras besoin d'une autre code pour tous les champs sur un évènement choisi.
    J'ai pas encore de décodeur, alors, postez en clair ! Comment mettre une balise de code ?
    Débutez en VBA

    Mes articles


    Dans un MP, vous pouvez me dire que je suis beau, ... mais si c'est une question technique je ne la lis pas ! Vous êtes prévenus !

  3. #3
    Membre régulier
    Femme Profil pro
    Formatrice bureautique
    Inscrit en
    Septembre 2007
    Messages
    202
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 47
    Localisation : Suisse

    Informations professionnelles :
    Activité : Formatrice bureautique

    Informations forums :
    Inscription : Septembre 2007
    Messages : 202
    Points : 79
    Points
    79
    Par défaut La solution
    Pour info, voici le code pour que ça fonctionne ;-)

    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
    75
    76
    77
    78
    79
    80
    81
    82
    83
    Private Function IsFieldEmpty(FF As FormField) As Boolean
        IsFieldEmpty = False ' default
     
        If FF.Type = wdFieldFormTextInput Then
            If Len(Trim(FF.Result)) = 0 Then
                MsgBox prompt:="Field " & FF.Name & _
                    " must not be blank.", Title:="Empty Field"
                FF.Range.Select
                IsFieldEmpty = True
            End If
        End If
    End Function
     
    Sub FilePrint()
        Dim FrmFld As FormField
        Dim StopPrint As Boolean
     
        For Each FrmFld In ActiveDocument.FormFields
            StopPrint = IsFieldEmpty(FrmFld)
            If StopPrint Then Exit For
        Next FrmFld
     
        If Not StopPrint Then
            Dialogs(wdDialogFilePrint).Show
        End If
    End Sub
     
    Sub FilePrintDefault()
        Dim FrmFld As FormField
        Dim StopPrint As Boolean
     
        For Each FrmFld In ActiveDocument.FormFields
            StopPrint = IsFieldEmpty(FrmFld)
            If StopPrint Then Exit For
        Next FrmFld
     
        If Not StopPrint Then
            ActiveDocument.PrintOut
        End If
    End Sub
     
    Sub FileSave()
        Dim FrmFld As FormField
        Dim StopSave As Boolean
     
        For Each FrmFld In ActiveDocument.FormFields
            StopSave = IsFieldEmpty(FrmFld)
            If StopSave Then Exit For
        Next FrmFld
     
        If Not StopSave Then
            ActiveDocument.Save
        End If
    End Sub
     
    Sub FileSaveAs()
        Dim FrmFld As FormField
        Dim StopSave As Boolean
     
        For Each FrmFld In ActiveDocument.FormFields
            StopSave = IsFieldEmpty(FrmFld)
            If StopSave Then Exit For
        Next FrmFld
     
        If Not StopSave Then
            Dialogs(wdDialogFileSaveAs).Show
        End If
    End Sub
     
    Sub AutoClose()
        Dim FrmFld As FormField
        Dim StopSave As Boolean
     
        For Each FrmFld In ActiveDocument.FormFields
            StopSave = IsFieldEmpty(FrmFld)
            If StopSave Then Exit For
        Next FrmFld
     
        If StopSave Then
            ActiveDocument.Saved = False
            SendKeys "{ESC}"
        End If
    End Sub

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

Discussions similaires

  1. Réponses: 4
    Dernier message: 24/07/2014, 16h08
  2. Réponses: 17
    Dernier message: 26/09/2012, 11h29
  3. [AC-2010] Texte ce rendre sur un champ texte pret a écrire dans un formulaire
    Par scado dans le forum VBA Access
    Réponses: 6
    Dernier message: 21/12/2010, 16h38
  4. Interdir la saisie des champs texte des formulaires
    Par fisio dans le forum VBA Access
    Réponses: 5
    Dernier message: 25/05/2009, 23h46
  5. rendre visible des champs de texte
    Par lnikolanta dans le forum Général JavaScript
    Réponses: 17
    Dernier message: 16/09/2005, 18h07

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