Exercice 2 HTML et CSS Corrigé S4

Exercice Avancé : Formulaire d'Inscription avec Validation et Interaction Dynamique

Objectif :
Créer un formulaire HTML complexe avec validation avancée, interaction dynamique, et intégration de fonctionnalités modernes. Le formulaire doit inclure plusieurs types d'inputs et utiliser JavaScript pour des validations personnalisées et une interaction améliorée.

Travail à réaliser :

  1. Champs de saisie :

    • Nom : Champ de texte obligatoire avec une validation pour que le nom contienne uniquement des lettres.
    • Prénom : Champ de texte obligatoire avec une validation pour que le prénom contienne uniquement des lettres.
    • E-mail : Champ de saisie d'e-mail obligatoire avec validation pour vérifier que l'adresse e-mail se termine par "oudev.net".
  2. Validation du mot de passe :

    • Mot de passe : Champ de saisie de mot de passe obligatoire avec validation JavaScript pour vérifier que le mot de passe contient entre 6 et 8 caractères, dont au moins un chiffre.
  3. Boutons radio pour le choix du sexe :

    • Sexe : Deux boutons radio pour sélectionner le sexe de l'utilisateur (Homme ou Femme). Ajoutez une validation JavaScript pour vous assurer qu'un choix est effectué.
  4. Transfert de fichier photo :

    • Photo : Champ pour le transfert de fichier photo avec restriction aux formats JPEG ou PNG et une taille maximale de 2 Mo. Ajoutez une validation JavaScript pour afficher un message d'erreur si le fichier ne respecte pas les contraintes.
  5. Liste de choix pour les pays :

    • Pays : Liste déroulante pour sélectionner le pays de résidence. Implémentez une fonctionnalité JavaScript pour afficher des informations supplémentaires (comme des codes de pays) en fonction du pays sélectionné.
  6. Liste de choix multiple pour les langages préférés :

    • Langages préférés : Liste déroulante avec sélection multiple pour choisir les langages de programmation préférés. Ajoutez une fonctionnalité JavaScript pour afficher une liste de langages suggérés en fonction de la sélection de l'utilisateur.
  7. Cases à cocher pour les domaines d'activités :

    • Domaines d'activités : Cases à cocher pour sélectionner les domaines d'activités d'intérêt. Ajoutez une validation pour vérifier qu'au moins un domaine est sélectionné avant la soumission.
  8. Fonctionnalités supplémentaires :

    • Affichage dynamique des erreurs : Utilisez JavaScript pour afficher des messages d'erreur sous chaque champ en cas de validation échouée.
    • Modification dynamique de la couleur de fond : Utilisez du CSS et JavaScript pour changer la couleur de fond des champs en fonction de leur validité (par exemple, vert pour valide, rouge pour invalide).
    • Affichage de prévisualisation de la photo : Ajoutez une fonctionnalité JavaScript pour afficher un aperçu de la photo sélectionnée avant la soumission du formulaire.
  9. Consignes :

    • Créez un fichier HTML avec le formulaire décrit ci-dessus.
    • Utilisez du CSS pour styliser le formulaire de manière moderne et attrayante.
    • Implémentez des validations JavaScript pour les différents champs du formulaire.
    • Assurez-vous que le formulaire est accessible et utilisable sur les navigateurs modernes.

Exemple de formulaire :

 

<!DOCTYPE html>
<html lang="fr">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Formulaire d'inscription Avancé</title>
    <style>
        body {
            font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
            background-color: #f4f4f4;
            margin: 0;
            padding: 0;
        }

        .container {
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100vh;
        }

        .form-inscription {
            background-color: #fff;
            border-radius: 10px;
            padding: 30px;
            box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
            width: 100%;
            max-width: 700px;
        }

        h2 {
            text-align: center;
            color: #333;
            margin-bottom: 20px;
        }

        label {
            font-weight: bold;
            margin-bottom: 5px;
            display: inline-block;
        }

        input[type="text"], 
        input[type="email"], 
        input[type="file"], 
        select, 
        input[type="password"] {
            width: 100%;
            padding: 10px;
            margin-bottom: 15px;
            border: 1px solid #ccc;
            border-radius: 5px;
            font-size: 16px;
            box-sizing: border-box;
        }

        input[type="radio"], 
        input[type="checkbox"] {
            margin-right: 10px;
        }

        input[type="file"] {
            border: none;
        }

        button {
            width: 100%;
            background-color: #007BFF;
            color: #fff;
            padding: 12px;
            border: none;
            border-radius: 5px;
            font-size: 16px;
            cursor: pointer;
            transition: background-color 0.3s ease;
        }

        button:hover {
            background-color: #0056b3;
        }

        .radio-group, 
        .checkbox-group {
            margin-bottom: 15px;
        }

        .info-text {
            font-size: 14px;
            color: #777;
        }

        .error {
            color: red;
            font-size: 14px;
        }

        input:valid {
            background-color: #d4edda; /* Vert clair */
        }

        input:invalid {
            background-color: #f8d7da; /* Rouge clair */
        }

      

        #photoPreview {
            max-width: 45px;
            max-height: 45px;
            width: 45px; /* Fixe la largeur */
            height: 45px; /* Fixe la hauteur */
            object-fit: cover; /* Maintient les proportions sans déformation */
            display: none;
        }

    </style>
</head>
<body>
    <div class="container">
        <div class="form-inscription">
            <h2>Formulaire d'inscription Avancé</h2>
            <form id="registrationForm" action="#" method="POST" enctype="multipart/form-data">
                <!-- Nom -->
                <label for="nom">Nom :</label>
                <input type="text" id="nom" name="nom" required placeholder="Entrez votre nom">
                <div id="nomError" class="error"></div>

                <!-- Prénom -->
                <label for="prenom">Prénom :</label>
                <input type="text" id="prenom" name="prenom" required placeholder="Entrez votre prénom">
                <div id="prenomError" class="error"></div>

                <!-- E-mail -->
                <label for="email">E-mail :</label>
                <input type="email" id="email" name="email" required placeholder="exemple@oudev.net">
                <div id="emailError" class="error"></div>

                <!-- Mot de passe -->
                <label for="password">Mot de passe :</label>
                <input type="password" id="password" name="password" required pattern="(?=.*\d)[A-Za-z\d]{6,8}" placeholder="6-8 caractères, inclure au moins un chiffre">
                <div id="passwordError" class="error"></div>

                <!-- Sexe (boutons radio) -->
                <div class="radio-group">
                    <label>Sexe :</label>
                    <input type="radio" id="homme" name="sexe" value="homme" required>
                    <label for="homme">Homme</label>
                    <input type="radio" id="femme" name="sexe" value="femme">
                    <label for="femme">Femme</label>
                </div>
                <div id="sexeError" class="error"></div>

                <!-- Transfert de fichier (photo) -->
                <label for="photo">Photo (JPEG ou PNG) :</label>
                <input type="file" id="photo" name="photo" accept=".jpeg, .jpg, .png" required>
                <img id="photoPreview" alt="Aperçu de la photo">
                <div id="photoError" class="error"></div>
                <p class="info-text">Formats acceptés : JPEG, PNG, Taille max : 2 Mo</p>

                <!-- Liste de choix pour les pays -->
                <label for="pays">Pays :</label>
                <select id="pays" name="pays" required>
                    <option value="">Sélectionnez un pays</option>
                    <option value="france">France</option>
                    <option value="algerie">Algérie</option>
                    <option value="canada">Canada</option>
                    <option value="belgique">Belgique</option>
                </select>
                <div id="paysInfo" class="info-text"></div>

                <!-- Liste de choix multiple pour les langages -->
                <label for="langages">Langages préférés :</label>
                <select id="langages" name="langages[]" multiple size="4" required>
                    <option value="python">Python</option>
                    <option value="java">Java</option>
                    <option value="javascript">JavaScript</option>
                    <option value="php">PHP</option>
                    <option value="c++">C++</option>
                </select>
                <p class="info-text">Maintenez "Ctrl" pour sélectionner plusieurs langages</p>

                <!-- Cases à cocher pour les domaines d'activités -->
                <div class="checkbox-group">
                    <label>Domaines d'activités :</label>
                    <input type="checkbox" id="informatique" name="domaines[]" value="informatique">
                    <label for="informatique">Informatique</label>
                    <input type="checkbox" id="medecine" name="domaines[]" value="medecine">
                    <label for="medecine">Médecine</label>
                    <input type="checkbox" id="education" name="domaines[]" value="education">
                    <label for="education">Éducation</label>
                </div>
                <div id="domainesError" class="error"></div>

                <!-- Bouton de soumission -->
                <button type="submit">S'inscrire</button>
            </form>
        </div>
    </div>

    <script>
        document.getElementById('registrationForm').addEventListener('submit', function(event) {
            let valid = true;

            // Validation des champs de texte
            const nom = document.getElementById('nom');
            const prenom = document.getElementById('prenom');
            const email = document.getElementById('email');
            const password = document.getElementById('password');
            const sexe = document.querySelector('input[name="sexe"]:checked');
            const photo = document.getElementById('photo');
            const domaines = document.querySelectorAll('input[name="domaines[]"]:checked');

            // Validation nom
            if (!/^[a-zA-Z]+$/.test(nom.value)) {
                document.getElementById('nomError').textContent = 'Le nom ne doit contenir que des lettres.';
                valid = false;
            } else {
                document.getElementById('nomError').textContent = '';
            }

            // Validation prénom
            if (!/^[a-zA-Z]+$/.test(prenom.value)) {
                document.getElementById('prenomError').textContent = 'Le prénom ne doit contenir que des lettres.';
                valid = false;
            } else {
                document.getElementById('prenomError').textContent = '';
            }

            // Validation e-mail
            if (!/^[\w._%+-]+@oudev\.net$/.test(email.value)) {
                document.getElementById('emailError').textContent = 'L\'e-mail doit se terminer par "oudev.net".';
                valid = false;
            } else {
                document.getElementById('emailError').textContent = '';
            }

            // Validation mot de passe
            if (!password.value.match(/^(?=.*\d)[A-Za-z\d]{6,8}$/)) {
                document.getElementById('passwordError').textContent = 'Le mot de passe doit contenir entre 6 et 8 caractères, dont au moins un chiffre.';
                valid = false;
            } else {
                document.getElementById('passwordError').textContent = '';
            }

            // Validation sexe
            if (!sexe) {
                document.getElementById('sexeError').textContent = 'Veuillez sélectionner un sexe.';
                valid = false;
            } else {
                document.getElementById('sexeError').textContent = '';
            }

            // Validation photo
            if (photo.files.length > 0) {
                const file = photo.files[0];
                if (file.size > 2 * 1024 * 1024) {
                    document.getElementById('photoError').textContent = 'La taille du fichier ne doit pas dépasser 2 Mo.';
                    valid = false;
                } else if (!/\.(jpg|jpeg|png)$/i.test(file.name)) {
                    document.getElementById('photoError').textContent = 'Le fichier doit être au format JPEG ou PNG.';
                    valid = false;
                } else {
                    document.getElementById('photoError').textContent = '';
                }
            } else {
                document.getElementById('photoError').textContent = 'Veuillez sélectionner une photo.';
                valid = false;
            }

            // Validation domaines d'activités
            if (domaines.length === 0) {
                document.getElementById('domainesError').textContent = 'Veuillez sélectionner au moins un domaine d\'activité.';
                valid = false;
            } else {
                document.getElementById('domainesError').textContent = '';
            }

            if (!valid) {
                event.preventDefault(); // Empêche l'envoi du formulaire si les validations échouent
            }
        });

        // Affichage de prévisualisation de la photo
        document.getElementById('photo').addEventListener('change', function() {
            const file = this.files[0];
            const preview = document.getElementById('photoPreview');

            if (file) {
                const reader = new FileReader();
                reader.onload = function(e) {
                    preview.src = e.target.result;
                    preview.style.display = 'block';
                };
                reader.readAsDataURL(file);
            } else {
                preview.src = '';
                preview.style.display = 'none';
            }
        });

        // Affichage dynamique des informations sur les pays
        document.getElementById('pays').addEventListener('change', function() {
            const paysInfo = document.getElementById('paysInfo');
            const selectedCountry = this.value;

            if (selectedCountry) {
                // Exemples d'informations supplémentaires
                const info = {
                    'france': 'Code : FR, Langue : Français',
                    'algerie': 'Code : DZ, Langue : Arabe',
                    'canada': 'Code : CA, Langue : Anglais, Français',
                    'belgique': 'Code : BE, Langue : Français, Néerlandais'
                };
                paysInfo.textContent = info[selectedCountry] || '';
            } else {
                paysInfo.textContent = '';
            }
        });
    </script>
</body>
</html>

 


  • oudevnet
    oudevnet

    Sept. 13, 2024, 10:32 p.m.

    si vous souhaitez de tels exercices dites-le-nous dans commentairesyes

Ajouter un commentaire

Veuillez vous   connecter pour ajouter un commentaire.