Formulaire avec Javascript

playboy-1990 Messages postés 593 Statut Membre -  
Alain_42 Messages postés 5413 Statut Membre -
Bonjour,
Je voudrais savoir le code Javascript que je dois mettre pour que le javascript vérifie que l'internaute à mis plus de 4 caractère et non des espaces dans le champs text
avec un message si il indique moins de cratère et la validation du formulaire si il à indiquer plus de 4 ou plus de caractère

Merci

12 réponses

  1. playboy-1990 Messages postés 593 Statut Membre 273
     
    Quelqu'un peux m'aidez ?
    2
  2. playboy-1990 Messages postés 593 Statut Membre 273
     
    Mille fois merci !!
    Peux tu me dire ou tu à trouvé ce tutoriel car il est super !
    1
  3. Alain_42 Messages postés 5413 Statut Membre 904
     
    inspires toi de cet exemple
    avec le onSubmit="return verif(.....

    <script type="text/javascript">
    function verif(id) 
    {
    	var Reg = new RegExp("^[0-9A-Za-z]{4,}$","g"); 
    	/*regle de test:
    	^ du début de la chaine
    	$ à la fin
    	[0-9A-Za-z] chiffres ou lettre majuscule ou minuscule
    	{4,}  4 minimum	si tu mets 4,12  tu autorise de 4 à 12
    	*/
    	
    	var saisie= document.getElementById(id).value; //on lit la saisie
    	//test
    		if(!Reg.test(saisie)) 
    		{ 
    			alert ("vous devez saisir au moins 4 caractères et sans espace !");
    			return false; //return false empeche le form de partir
    		}else{
    			return true; //autorise l'envoi
    
    	}		
    	  
    }
    </script>
    
    <form action="" method="post"name="form1" onSubmit="return verif('id_champ1');"> 	
    	<input type="text" id="id_champ1" name="champ1" value=""  /><br /> 
    	<input type="submit" name="envoyer" value="Envoyer" /> 
    </form> 
    0
  4. Alain_42 Messages postés 5413 Statut Membre 904
     
    ce n'est pas un tuto, je t'ai fait cet exemple
    0
  5. Vous n’avez pas trouvé la réponse que vous recherchez ?

    Posez votre question
  6. playboy-1990 Messages postés 593 Statut Membre 273
     
    Et maintenant si je met 2 champs comment je fais avec
    onSubmit="return verif('id_champ1');

    J'ai eassyé avec
     onSubmit="return verif('id_champ1'); && ('id_champ2');"> 	

    Mais ça ne fonctionne pas
    0
  7. Alain_42 Messages postés 5413 Statut Membre 904
     
    onSubmit="return verif('id_champ1'); && ('id_champ2');">

    la c'est pas bon, il faut passer deux arguments séparés par une virgule, à la fonction javascript
    onSubmit="return verif('id_champ1','id_champ2'); "> 


    et bien sur modifier la fonction pour qu'elle reçoive ces deux arguments:
    function verif(id1,id2) 
    {
    	var Reg = new RegExp("^[0-9A-Za-z]{4,}$","g"); 
    	/*regle de test:
    	^ du début de la chaine
    	$ à la fin
    	[0-9A-Za-z] chiffres ou lettre majuscule ou minuscule
    	{4,}  4 minimum	si tu mets 4,12  tu autorise de 4 à 12
    	*/
    	
    	var saisie1= document.getElementById(id1).value; //on lit la saisie du premier champ
    	//test
    		if(!Reg.test(saisie1)) 
    		{ 
    			alert ("vous devez saisir au moins 4 caractères et sans espace !");
    			return false; //return false empeche le form de partir
    		}
    
    		var saisie2= document.getElementById(id2).value; //on lit la saisie du deuxieme champ	
    		if(!Reg.test(saisie2)) 
    		{ //mais la tu peux faire un autre type de test si tu veux en faisant une autre Reg
    			alert ("vous devez saisir au moins 4 caractères et sans espace !");
    			return false; //return false empeche le form de partir
    			
    		}
    			
    	//si on est arrivé la c'est que les deux champs sont ok donc on return true
    	return true; //autorise l'envoi
    	  
    }
    
    
    0
  8. playboy-1990 Messages postés 593 Statut Membre 273
     
    Un grand merci
    Mais j'ai un petit problème quand je mets mon pseudo (plus de quatre caractère et mon mot de passe (plus de quatre caractère il ne veut pas envoyer le formulaire et reste bloqué dans le champ de mot de passe

    Voici le code au complet pour que vous pussiez voir le problème
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
      "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xml:lang="en" lang="en" xmlns="http://www.w3.org/1999/xhtml">
    <head>
    </head>
    <body>
    <script type="text/javascript">
    function verif(id1,id2) 
    {
    	var Reg = new RegExp("^[0-9A-Za-z]{4,}$","g"); 
    	/*regle de test:
    	^ du début de la chaine
    	$ à la fin
    	[0-9A-Za-z] chiffres ou lettre majuscule ou minuscule
    	{4,}  4 minimum	si tu mets 4,12  tu autorise de 4 à 12
    	*/
    	
    	var saisie1= document.getElementById(id1).value; //on lit la saisie du premier champ
    	//test
    		if(!Reg.test(saisie1)) 
    		{ 
    			alert ("Veuillez indiquer un pseudo!");
    			return false; //return false empeche le form de partir
    		}
    
    		var saisie2= document.getElementById(id2).value; //on lit la saisie du deuxieme champ	
    		if(!Reg.test(saisie2)) 
    		{ //mais la tu peux faire un autre type de test si tu veux en faisant une autre Reg
    			alert ("Veuillez indiquer un mot de passe !");
    			return false; //return false empeche le form de partir
    			
    		}
    			
    	//si on est arrivé la c'est que les deux champs sont ok donc on return true
    	return true; //autorise l'envoi
    	  
    }
    
    </script>
    <form method="post" action="chat.php" onSubmit="return verif('id_champ1','id_champ2'); ">   
        <input name="pseudo" type="text" id="id_champ1" tabindex="1" value="Votre pseudo" onfocus="javascript:if(this.value == 'Votre pseudo') { this.value = ''; }" /> 
        <input name="passe" type="password" id="id_champ2" tabindex="2" value="******" onfocus="javascript:if(this.value == '******') { this.value = ''; }" />
    <input type="submit" name="envoyer" value="Envoyer" /> 
    </form> 
    </body>
    </html> 


    Et encore une petit question
    Dans mon formulaire je mes les deux champs avec un value
    <form method="post" action="chat.php" onSubmit="return verif('id_champ1','id_champ2'); ">    
        <input name="pseudo" type="text" id="id_champ1" tabindex="1" value="Votre pseudo" onfocus="javascript:if(this.value == 'Votre pseudo') { this.value = ''; }" />  
        <input name="passe" type="password" id="id_champ2" tabindex="2" value="******" onfocus="javascript:if(this.value == '******') { this.value = ''; }" />


    Je voudrais savoir comment je peux faire pour interdire que l'internaute laisse les champs par défaut (Votre pseudo et *****)

    Merci
    0
  9. Alain_42 Messages postés 5413 Statut Membre 904
     
    tu rajoutes un autre test pour chacun des champs

    if(!Reg.test(saisie1)) 
    		{ 
    			alert ("vous devez saisir au moins 4 caractères et sans espace !");
    			return false; //return false empeche le form de partir
    		}
    //tu rajoutes ça pour le premier
    	if(saisie1=="Votre pseudo") 
    		{ 
    			alert ("vous devez saisir votre pseudo!");
    			return false; //return false empeche le form de partir
    		}
    
    et même principe pour l'autre
    
    0
  10. playboy-1990 Messages postés 593 Statut Membre 273
     
    Merci
    P.S j'ai modifier mon message car j'ai une petit erreur
    Voir message précédant
    0
  11. Alain_42 Messages postés 5413 Statut Membre 904
     
    quel message, quelle erreur ?
    0
  12. playboy-1990 Messages postés 593 Statut Membre 273
     
    j'ai un petit problème quand je mets mon pseudo (plus de quatre caractère) et mon mot de passe (plus de quatre caractère) il ne veut pas envoyer le formulaire et reste bloqué dans le champ de mot de passe

    Il indique toujours "Veuillez indiquer un mot de passe !"

    Voici le code au complet pour que vous pussiez voir le problème
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xml:lang="en" lang="en" xmlns="http://www.w3.org/1999/xhtml">
    <head>
    </head>
    <body>
    <script type="text/javascript">
    function verif(id1,id2)
    {
    var Reg = new RegExp("^[0-9A-Za-z]{4,}$","g");
    /*regle de test:
    ^ du début de la chaine
    $ à la fin
    [0-9A-Za-z] chiffres ou lettre majuscule ou minuscule
    {4,} 4 minimum si tu mets 4,12 tu autorise de 4 à 12
    */

    var saisie1= document.getElementById(id1).value; //on lit la saisie du premier champ
    //test
    if(!Reg.test(saisie1))
    {
    alert ("Veuillez indiquer un pseudo!");
    return false; //return false empeche le form de partir
    }

    var saisie2= document.getElementById(id2).value; //on lit la saisie du deuxieme champ
    if(!Reg.test(saisie2))
    { //mais la tu peux faire un autre type de test si tu veux en faisant une autre Reg
    alert ("Veuillez indiquer un mot de passe !");
    return false; //return false empeche le form de partir

    }

    //si on est arrivé la c'est que les deux champs sont ok donc on return true
    return true; //autorise l'envoi

    }

    </script>
    <form method="post" action="chat.php" onSubmit="return verif('id_champ1','id_champ2'); ">
    <input name="pseudo" type="text" id="id_champ1" tabindex="1" value="Votre pseudo" onfocus="javascript:if(this.value == 'Votre pseudo') { this.value = ''; }" />
    <input name="passe" type="password" id="id_champ2" tabindex="2" value="******" onfocus="javascript:if(this.value == '******') { this.value = ''; }" />
    <input type="submit" name="envoyer" value="Envoyer" />
    </form>
    </body>
    </html>

    A essayer
    0
  13. Alain_42 Messages postés 5413 Statut Membre 904
     
    <script type="text/javascript">
    function verif(id1,id2)
    {
    var Reg = new RegExp("^[0-9A-Za-z]{4,}$","g");
    /*regle de test:
    ^ du début de la chaine
    $ à la fin
    [0-9A-Za-z] chiffres ou lettre majuscule ou minuscule
    {4,} 4 minimum si tu mets 4,12 tu autorise de 4 à 12
    */
    
    var saisie1= document.getElementById(id1).value; //on lit la saisie du premier champ
    //test
    if(!Reg.test(saisie1))
    {
    alert ("Veuillez indiquer un pseudo!");
    return false; //return false empeche le form de partir
    }
    //apparement il faut refaire la new RegExp après usage
    var Reg = new RegExp("^[0-9A-Za-z]{4,}$","g");
    var saisie2= document.getElementById(id2).value; //on lit la saisie du deuxieme champ
    alert("Saisie2:"+saisie2);
    if(!Reg.test(saisie2))
    { //mais la tu peux faire un autre type de test si tu veux en faisant une autre Reg
    alert ("Veuillez indiquer un mot de passe !");
    return false; //return false empeche le form de partir
    
    }
    
    //si on est arrivé la c'est que les deux champs sont ok donc on return true
    return true; //autorise l'envoi
    
    }
    0