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

JavaScript Discussion :

Mon formulaire de validation ne fonctionne pas/plus ?


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Septembre 2009
    Messages
    458
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ressources humaines

    Informations forums :
    Inscription : Septembre 2009
    Messages : 458
    Par défaut Mon formulaire de validation ne fonctionne pas/plus ?
    Bonjour,

    Dans mon formulaire, j'ai deux champs qui sont le nom et la date de naissance.

    En gros, si la date de naissance est inférieur à 1900, alors un message d'erreur doit être affiché. Depuis que j'ai tenté de faire ce genre d'algo, plus rien ne fonctionne.

    Je ne comprends pas ce qui bug ?



    Code HTML : 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
    <!DOCTYPE html>
    <html lang="fr">
    <head>
      <meta charset="utf-8">
      <title>Titre de la page</title>
      <link rel="stylesheet" href="style.css">
      <script src="script.js"></script>
    </head>
    <body>
    <form action="#" onsubmit="return validation()" >
    <br>
    <label>Name : </label>
    <br>
    <input type="text" name="name" id="name">
    <br>
    <span id="nameError"></span>
    <br>
    <label>Date of birth : </label>
    <br>
    <input type="date" name="dateofbirth" id="dateofbirth">
    <br>
    <span id="dateofbirthError"></span>
    <br>
    <input type="submit" value="ok">
    </form>
    </body>
    </html>

    JS


    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
    function validation() {
     
        var name = document.getElementById('name').value;
        var dateofbirth = document.getElementById('dateofbirth').value;
     
        if(name == ""){
            document.getElementById('nameError').innerHTML = " ** the name field is empty ! ";
             return false;
        }
     
        if(name.length < 2){
            document.getElementById('nameError').innerHTML = " ** min 2 characters ! ";
            return false;
        }
     
        if(!isValidDate(dateofbirth)){
            document.getElementById('dateofbirthError').innerHTML = " ** the date field is empty ! ";
            return false;
        }
    }
     
     
     
    function isValidDate(str) {
     
        var getvalue = str.split('-');
        var day = getvalue[2];
        var month = getvalue[1];
        var year = getvalue[0];
     
        if(year <= 1900){
            return false;
        }
        if (month < 1 || month > 12) { 
          return false;
         }
         if (day < 1 &|| day > 31) {
          return false;
         }
         if ((month==4 || month==6 || month==9 || month==11) && day==31) {
          return false;
         }
         if (month == 2) { 
          var isleap = (year % 4 == 0 && (year % 100 != 0 || year % 400 == 0));
          if (day>29 || (day==29 && !isleap)) {
           return false;
            }
         }
         else{
            return true;
     
         }
    }

  2. #2
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 684
    Par défaut
    Je dirais: String vs Number;

  3. #3
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 684
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 684
    Par défaut
    Ah non, tu as un opérateur pas homologué à la ligne 37:
    Dis si tu as d'autres problèmes et surtout les messages d'erreur de la console parce que "plus rien ne fonctionne" n'a pas tellement de sens, sur ce forum.

Discussions similaires

  1. [AC-2003] mon formulaire de tri ne fonctionne pas
    Par revemane dans le forum IHM
    Réponses: 2
    Dernier message: 03/03/2011, 19h47
  2. Mon tri de date ne fonctionne pas bien :(
    Par rohstev dans le forum Macros et VBA Excel
    Réponses: 3
    Dernier message: 18/07/2007, 10h58
  3. [osCommerce] Lien "mon compte" et "commander" ne fonctionne pas
    Par sasaas dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 1
    Dernier message: 25/06/2007, 16h59
  4. Réponses: 18
    Dernier message: 19/04/2007, 17h42
  5. Réponses: 7
    Dernier message: 24/01/2006, 11h03

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