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 :

Contrôle de formulaire


Sujet :

JavaScript

  1. #1
    Membre averti
    Inscrit en
    Octobre 2006
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 12
    Par défaut Contrôle de formulaire
    Bonjour,
    Je genere un formulaire html, un des champs demande le nombre de couleur dans une liste deroulante alant de 1 à 4.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    Nombre de couleur :
    <select name="nombre_couleur" id="nombre_couleur" OnChange="ajoutChamp()" >
      <option value="0" selected="selected">Nombre de couleur...</option>
      <option value="1">1</option>
      <option value="2">2</option>
      <option value="3">3</option>
      <option value="4">4</option>
    </select>
    <br />
    <br />
    <div id = "namecolor"></div>
    En fonction de ce choix il y a autant de zone texte intitulé nom_couleurX (ou X est une incrementation de 1 à 4) générées par un code javascipt :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    function ajoutChamp(){
    	index = document.ajoutCliche.nombre_couleur.selectedIndex;
    	code = "";
    	for (i=0;i<=(index - 1);i++) {
    		code += "Nom Couleur " + (i+1) +" : <input type=\"text\" name=\"nom_couleur" + i + " id=\"nom_couleur" + i +"\" />\n";
    	 }
     
    	//alert('' + code);
    		document.getElementById("namecolor").innerHTML = code;
     
    }
    Mon probleme est que je cherche à vérifier que certains champs de mon formulaire soient bien renseignés. Je fais cela par une fonction javascript via un OnClick du bouton valider :

    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
    function testform(){
     
    var msg = "Merci de choisir :\n" ; 
    lgMsg = msg.length ;
    index = document.ajoutCliche.nombre_couleur.selectedIndex;
    		(...)
    if(document.getElementById("nombre_couleur").value == 0)
    				{
    						msg += "> un nombre de couleur\n";
    						}
     
    		for (i=0;i<=(index - 1);i++) {
    			if(document.getElementById("nom_couleur" + i + "").value == 0)
    				{
    						msg += "> un nom de couleur " + (i+1) + "\n";
    						}
     
    									}
     
    //si le message d'erreur ne recoit pas de concatenation en plus alors c'est qu'il n'y a pas d'erreur, le formulaire peut donc etre transmis
    				if ( msg.length > lgMsg ) {
    		 		alert(msg) ;
    		       return false;
    		        } else {
             return true; }
    }
    Les tests de remplissage du formulaire fonctionnent tres bien sauf sur les champs nom_couleurX. Pourriez vous m'aider à comprendre mon erreur ?
    Merci

  2. #2
    Inactif  

    Homme Profil pro
    développeur Vala
    Inscrit en
    Février 2011
    Messages
    478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Cher (Centre)

    Informations professionnelles :
    Activité : développeur Vala
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2011
    Messages : 478
    Par défaut
    bon, comme tu n'as posté l'intégralité du code html, j'ai fait avec .
    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
     
    <html>
    <body>
    Nombre de couleur :
    <form name="ajoutCliche">
    <select name="nombre_couleur" id="nombre_couleur" OnChange="ajoutChamp(this)" >
      <option value="0" selected="selected">Nombre de couleur...</option>
      <option value="1">1</option>
      <option value="2">2</option>
      <option value="3">3</option>
      <option value="4">4</option>
    </select>
    <input type="button" onclick="testform(ajoutCliche.nombre_couleur);" />
    </form>
    <br />
    <br />
    <div id = "namecolor"></div>
    <script>
    function ajoutChamp(liste){
    	var index = liste.selectedIndex;
    	var code = "";
    	for (var i=0;i<=(index - 1);i++) {
    		code += 'Nom Couleur '+(i+1)+' : <input type="text" name="nom_couleur'+i+'" id="nom_couleur'+i+'"><br>';
    	 }
    document.getElementById("namecolor").innerHTML = code;
    }
     
    function testform(liste){
     
    var msg = "Merci de choisir :\n" ; 
    lgMsg = msg.length ;
    index = liste.selectedIndex;
    if(liste.options[index].value == 0)
    				{
    						msg += "> un nombre de couleur\n";
    						}
     
    		for (i=0;i<=(index - 1);i++) {
    			if(document.getElementById("nom_couleur"+i).value == 0)
    				{
    						msg += "> un nom de couleur " + (i+1) + "\n";
    						}
     
    									}
     
    //si le message d'erreur ne recoit pas de concatenation en plus alors c'est qu'il n'y a pas d'erreur, le formulaire peut donc etre transmis
    				if ( msg.length > lgMsg ) {
    		 		alert(msg) ;
    		       return false;
    		        } else {
             return true; }
    }
    </script>
    </body>
    </html>
    ton erreur sur les contrôles des champs de couleur se situait au fait que tu faisais
    il fallait faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select.options[index].value
    tu utilise le tableau des options de ton select à l'index sélectionné

    signale moi si je ne suis pas assez clair !

  3. #3
    Inactif  

    Profil pro
    Inscrit en
    Mai 2010
    Messages
    345
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mai 2010
    Messages : 345
    Par défaut
    Citation Envoyé par rotrevrep Voir le message
    ton erreur sur les contrôles des champs de couleur se situait au fait que tu faisais
    il fallait faire
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select.options[index].value
    tu utilise le tableau des options de ton select à l'index sélectionné

    signale moi si je ne suis pas assez clair !
    En fait tu as tord. Ecrire select.value est tout à fait valable et fonctionnel, et ce depuis IE5.5, ce sont les anciens navigateurs tous moisis qui obligeaient de faire un select.options[select.selectedIndex] mais c'est fini tout ça, le temps est révolu, place au select.value :o

  4. #4
    Inactif  

    Homme Profil pro
    développeur Vala
    Inscrit en
    Février 2011
    Messages
    478
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Cher (Centre)

    Informations professionnelles :
    Activité : développeur Vala
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Février 2011
    Messages : 478
    Par défaut
    Citation Envoyé par dukej Voir le message
    En fait tu as tord. Ecrire select.value est tout à fait valable et fonctionnel, et ce depuis IE5.5, ce sont les anciens navigateurs tous moisis qui obligeaient de faire un select.options[select.selectedIndex] mais c'est fini tout ça, le temps est révolu, place au select.value :o
    :S tu as raison.

  5. #5
    Membre averti
    Inscrit en
    Octobre 2006
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 12
    Par défaut
    Bonjour et merci de vous être poser sur mon soucis.
    Avez vous une idée de où ais je fais une erreur ?
    Merci

  6. #6
    Membre averti
    Inscrit en
    Octobre 2006
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 12
    Par défaut
    Je me permet de vous joindre tout le code html :

    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
     
    <html>
    <head>
    <title>Ajout cliché</title>
     
    <link href="css/site.css" rel="stylesheet" type="text/css" />
    <link href="css/calendrier.css" rel="stylesheet" type="text/css" />
    	<script type="text/javascript" src="js/calendrier.js"></script>
    	<script type="text/javascript" src="js/testformulaire.js"></script>
    </head>
     
    <body>
     
     
    <form action="traitementAjout.php" method="post" name="ajoutCliche" >
    <h3>
    <br />
    Date de création :
    <input type="text" name="date_creation" id="date_creation" value="23/11/2011" onclick="var date_crea = new calendar(this);"/>
    <br />
    <br />
    Date de derniére utilisation :
    <input type="text" name="date_derniere_utilisation" id="date_derniere_utilisation" value="23/11/2011" onclick="var date_dern = new calendar(this);"/>
    <br />
    <br />
    Numéro de tiroir :
    <input type="text" name="numero_tiroir" id="numero_tiroir" />
    <br />
    <br />
    Format de pochette (extérieur) :
    <input type="text" name="format_pochette" id="format_pochette" />
    <br />
    <br />
    Nom du client :
    <input type="text" name="nom_client" id="nom_client" />
    <br />
    <br />
    Désignation :
    <input type="text" name="designation" id="designation" />
    <br />
    <br />
    Référence client :
    <input type="text" name="reference_client" id="reference_client" />
    <br />
    <br />
    Nombre de couleur :
    <select name="nombre_couleur" id="nombre_couleur" OnChange="ajoutChamp()" >
      <option value="0" selected="selected">Nombre de couleur...</option>
      <option value="1">1</option>
      <option value="2">2</option>
      <option value="3">3</option>
      <option value="4">4</option>
    </select>
    <br />
    <br />
    <div id = "namecolor"></div>
    <br />
    <br />
    Laize :
    <input type="text" name="laize" id="laize" />
    <br />
    <br />
    Epaisseur Poly (dernière fabrication) :
    <input type="text" name="epaisseur_poly" id="epaisseur_poly" />
    <br />
    <br />
    <input name="valider" type="submit" value="Valider" OnClick="return testform()"/>  <input name="annuler" type="reset" value="Annuler" />  <input name="accueil" type="submit" value="retour" />
    </h3>
    </form>
    </body>
    </html>

  7. #7
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 202
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 202
    Par défaut
    Bonjour,
    visiblement un problème de guillemet/quote sur cette ligne
    code += "Nom Couleur " + (i+1) +" : <input type=\"text\" name=\"nom_couleur" + i + " id=\"nom_couleur" + i +"\" />\n";.
    tu ne fermes pas la chaine du name, preféres cette écriture
    code += 'Nom Couleur ' + (i+1) +' : <input type="text" name="nom_couleur' + i +'" id="nom_couleur' + i +'" />\n';

  8. #8
    Membre averti
    Inscrit en
    Octobre 2006
    Messages
    12
    Détails du profil
    Informations forums :
    Inscription : Octobre 2006
    Messages : 12
    Par défaut
    Mille merci !
    Quand on a trop le nez dedans on a du mal à voir ces/ses bêtises

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

Discussions similaires

  1. [PHP-JS] Classe de contrôle de formulaire
    Par MV1908 dans le forum Langage
    Réponses: 4
    Dernier message: 10/10/2006, 00h01
  2. Réponses: 1
    Dernier message: 21/07/2006, 05h56
  3. Les contrôles de formulaire, quel test optimal ?
    Par GTJuanpablo dans le forum Langage
    Réponses: 8
    Dernier message: 26/04/2006, 10h00
  4. accéder à un contrôle de formulaire avec un nom de tableau
    Par jibouze dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 30/06/2005, 23h57
  5. [JSP] [STRUTS] Contrôle de formulaire
    Par babylone7 dans le forum Servlets/JSP
    Réponses: 5
    Dernier message: 13/07/2004, 17h51

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