Signaler

Script formulaire JS non fonctionnel [Résolu]

Posez votre question moon136 30Messages postés samedi 12 août 2017Date d'inscription 6 octobre 2017 Dernière intervention - Dernière réponse le 23 août 2017 à 00:04 par moon136
bonjour mon script n'est plus fonctionnel , je tourne en rond avec le fichier js pour voir ce qui ne va pas. c au niveau de la fonction de calcul j'ai ajouter des choses pour supprimer les NaN.. ca marchait en ajoutant les accolades qui manquent mon script ne marche plus. Pouvez vous m'aider SVP ?

<!DOCTYPE html PUBLIC>
<html>
<head>
<meta charset="utf-8" />
<title>mon formulaire</title>
<link rel="stylesheet" href="style.css">
<script src="formulaire.js"></script>
</head>
<body>
 <form id="Formulaire" name="Formulaire" enctype="text/plain" method="post" action="mailto:monmail@outlook.fr.com?subject=test">
  <h2>Formulaire de réservation :</h2>
  <p>(* = champ obligatoire)</p>
  <ul>
   <li>
    <label for="nom">Nom :*</label><input type="text" id="nom" name="nom" placeholder="Votre nom ici" required />
   </li>
   <li>
    <label for="prenom">Prénom :</label><input type="text" id="prenom" name="prenom" placeholder="Votre prénom ici" />
   </li>
   <li>
    <label for="tel">Téléphone :</label><input type="tel" id="tel" name="tel" maxlength="10" placeholder="0123456789" />
   </li>
   <li>
    <label for="mail">Email :*</label><input type="email" id="mail" name="mail" placeholder="xxx@yyyy.zzz" required />
   </li>
   <li>
    <label for="resa">Votre réservation est pour :</label>
    <select id="resa1" name="resa1" >
     <option value="demijour">Demi-journée</option>
     <option value="jour">Journée</option>
     <option value="repas">Repas</option>
    </select>
    <input type="text" id="nombre1" name="nombre1" placeholder="Qté" />
    <input type="text" id="stot1" name="stot1" placeholder="Sous-total HT" disabled />
    <label></label>
    <select id="resa2" name="resa2" >
     <option value="demijour">Demi-journée</option>
     <option value="jour" selected>Journée</option>
     <option value="repas">Repas</option>
    </select>
    <input type="text" id="nombre2" name="nombre2" placeholder="Qté" />
    <input type="text" id="stot2" name="stot2" placeholder="Sous-total HT" disabled /><br>
    <label></label>
    <select id="resa3" name="resa3" >
     <option value="demijour">Demi-journée</option>
     <option value="jour">Journée</option>
     <option value="repas" selected>Repas</option>
    </select>
    <input type="text" id="nombre3" name="nombre3" placeholder="Qté" />
    <input type="text" id="stot3" name="stot3" placeholder="Sous-total HT" disabled />
   </li>
   <li>
    <label for="st">Sous-total HT:</label><input type="text" id="st" name="st" placeholder="Sous-total HT" disabled/> euros
   </li>
   <li>
    <label for="total">Total TTC (TVA 20%):</label><input type="text" id="total" placeholder="Total TTC" name="total" disabled/> euros
   </li>
   <li>
    <label id="cdtgl" for="cdtgl">J'accepte les conditions générales *</label>
    <input type="checkbox" id="cg" name="cg" required />
   </li>
   <li><br /></li>
   <li>
    <input type="button" id="verifier" value="Vérifier avant envoi" />
    <input type="button" id="imprimer" value="Imprimer" />
    <input type="reset" />
    <input type="button" id="envoyer" value="Envoyer ma commande" />
   </li>
  </ul>
 </form>
 <ul>
  <li>Tarif demi-journée : 8 euros</li>
  <li>Tarif journée : 15 euros</li>
  <li>Tarif repas : 7 euros</li>
 </ul>
 
 
</body>
</html>

 VerifFormulaire = 0;

function conditionsVerifiees() {
   var erreur =0;
   var erreurnom =0;
   var erreurmail =0;
   var Nom = document.getElementById("nom").value;
   var Mail = document.getElementById("mail").value;
        var testMail = Mail.search("@");
   var IDNom = document.getElementById("nom");
   var IDMail = document.getElementById("mail");
   var Condition = document.getElementById("cg").checked;
   VerifFormulaire = 1;  
    if (Nom === "") {
        alert("Merci de saisir un nom.");
        IDNom.style.borderColor = "#FF0000";
        erreur++; 
  erreurnom =1;
    } else if (Mail === "") {    
        IDNom.style.borderColor = "#808080";
        alert("Merci de rentrer votre adresse e-mail");
        IDMail.style.borderColor = "#FF0000";
        erreur++;
  erreurmail =1;
    }
    else if (Mail ! == "" && testMail <= 0) {
  alert("Votre adresse e-mail n'est pas valide.");
  IDMail.style.borderColor = "#FF0000";
  erreur++;
  erreurmail =1;
    }
 else if (Condition==false) {
  document.getElementById("cg").style.borderColor = "#FF0000";
        alert("Avant l'envoie du formulaire, veuillez accepter les conditions générales en cochant la case.");
        erreur++;
    } else
 {        
        document.getElementById("cg").style.borderColor = "#808080";
  var nomMinuscules = Nom, nomMajuscules = nomMinuscules.toUpperCase();
        Nom = nomMajuscules;    
 }
 
 if (erreurnom==0) {
        IDNom.style.borderColor = "#808080";
 }
 if (erreurmail==0) {
        IDMail.style.borderColor = "#808080";
 }
 
 if (erreur>0){
    return VerifFormulaire=0
 else{
 return VerifFormulaire=1;
  redirect;
 }
 
}

// Fonction impression du formulaire
function impressionFormulaire() {
    window.print();
}

// Fonction On change value
function CalculerTotal() {
 var Valeur;
 var choix;
 Valeur = parseInt(document.getElementById("nombre1").value);
 alert(Valeur);
 if (isNaN(Valeur)) { Valeur = 0; }
 choix = document.getElementById("resa1").value;
 
 if (Valeur != ""){
  if (choix=="demijour")
  Valeur = Valeur*8; 
 }
  else{
  if (choix=="jour")
  Valeur = Valeur*15;
 }
  else{
  if (choix=="repas")
  Valeur = Valeur*7;
  document.getElementById("stot1").value = Valeur+" euros" ; 
  
 }else 
 Valeur = 0;


 var Valeur2=0;
 Valeur2 = parseInt(document.getElementById("nombre2").value);
 if (isNaN(Valeur2)) { Valeur2 = 0; }
 choix = document.getElementById("resa2").value;
 if (Valeur2!==''){
  if (choix=="demijour")
  Valeur2 = Valeur2*8; 
  else{
  if (choix=="jour")
  Valeur2 = Valeur2*15; 
  else
  if (choix=="repas")
  Valeur2 = Valeur2*7;
  document.getElementById("stot2").value = Valeur2+" euros" ;
 }else {
 valeur2 = 0;
 
 var Valeur3, totalht, tva, totalttc;
 Valeur3 = parseInt(document.getElementById("nombre3").value);
 if (isNaN(Valeur3)) { Valeur3 = 0; }
 choix = document.getElementById("resa3").value;
 if (Valeur3!=''){
  if (choix=="demijour")
  Valeur3 = Valeur3*8; 
  else{
  if (choix=="jour")
  Valeur3 = Valeur3*15;
  else{
  if (choix=="repas")
  Valeur3 = Valeur3*7;
  document.getElementById("stot3").value = Valeur3+" euros" ;
 }
 else{
 Valeur3 = 0;
 
 } 
 function totalht(){
 totalht = Valeur+Valeur2+Valeur3;
 tva = (totalht*20)/100;
 totalttc = totalht+tva;
 totalttc = totalttc.toFixed(2);
 document.getElementById("st").value = totalht;
 sousTotal = parseInt(document.getElementById("st").value);
 document.getElementById("total").value = totalttc;
}
}
// Vérification du formulaire
function testFormReservation() {
    if(VerifFormulaire == 0) {
        alert("Veuillez vérifier votre formulaire avant son envoi.");
    }
    else {
        document.getElementById("formulaire").submit();
    }
}


window.addEventListener("load", function () {
    document.getElementById("verifier").addEventListener("click", conditionsVerifiees);
    document.getElementById("envoyer").addEventListener("click", testFormReservation);
    document.getElementById("imprimer").addEventListener("click", impressionFormulaire);
    document.getElementById("nombre1").addEventListener("change", CalculerTotal);
    document.getElementById("nombre2").addEventListener("change", CalculerTotal);
    document.getElementById("nombre3").addEventListener("change", CalculerTotal);
    document.getElementById("resa1").addEventListener("change", CalculerTotal);
    document.getElementById("resa2").addEventListener("change", CalculerTotal);
    document.getElementById("resa3").addEventListener("change", CalculerTotal);
});


merci de votre aide
Utile
+0
plus moins
Bonjour

Commence par regarder dans la console du navigateur si il n'y a pas d'erreurs
Donnez votre avis
Utile
+0
plus moins
merci pour la reponse

j'ai regarder et j'ai ca comme message :
SyntaxError: missing ) after condition[En savoir plus]. donc il y a un probleme avec ma syntax if, else. c'est ca?

desolée je suis debutante
jordane45 18388Messages postés mercredi 22 octobre 2003Date d'inscription ModérateurStatut 9 octobre 2017 Dernière intervention - 21 août 2017 à 23:51
Oui visiblement c'est ce que signifie le message
Répondre
jordane45 18388Messages postés mercredi 22 octobre 2003Date d'inscription ModérateurStatut 9 octobre 2017 Dernière intervention - 22 août 2017 à 00:43
Au passage .. je t'invite (très très) fortement à utiliser la syntaxe suivante pour tes IF
if (condition) {
   instructions1;
   instructions2;
   instructionsN;
} else {
   instructions3;
   instructionsN;
}
Répondre
Donnez votre avis
Utile
+0
plus moins
bjr oui
mon principal probleme et je m'en sors pas car par exemple jai une accolade dans le if is NaN


if (isNaN(Valeur3)) { Valeur3 = 0; }{
	choix = document.getElementById("resa3").value;
		



et jai 2 if qui se suivent :


if (Valeur3!=''){
		if (choix==='demijour")
		Valeur3 = Valeur3*8;	}



c'est là que je crois que c'est faux
jordane45 18388Messages postés mercredi 22 octobre 2003Date d'inscription ModérateurStatut 9 octobre 2017 Dernière intervention - 22 août 2017 à 13:59
Oulaaaa...

premier code
if (isNaN(Valeur3)) { 
         Valeur3 = 0; 
	choix = document.getElementById("resa3").value;
}


Second code :
if (Valeur3!='') {
   if (choix==='demijour') {
      Valeur3 = Valeur3*8;	 
   } // fin du premier if

} // fin du second if
Répondre
Donnez votre avis
Utile
+0
plus moins
merci jordane , donc j'ai essayé pas à pas de nettoyer mon script il fonctionne mais pas au niveau des conditions je vois pas clair la .

(isNaN(Valeur)) { Valeur = 0; }
 choix = document.getElementById("resa1").value;
 
 if (choix==='demijour') {
      Valeur = Valeur*8;  
   } // fin du premier if

} // fin du second if

  else
  if (choix=="jour"){
  Valeur = Valeur*15;
  else if (choix=="repas"){
  Valeur = Valeur*7;
  document.getElementById("stot1").value = Valeur+" euros" ; 
 }else 
 {Valeur = 0};


 var Valeur2=0;
 Valeur2 = parseInt(document.getElementById("nombre2").value);
 if (isNaN(Valeur2)) { 
         Valeur2= 0; 
 choix = document.getElementById("resa3").value;
}
 if (choix==='demijour') {
      Valeur2 = Valeur2*8;  
   } // fin du premier if

} // fin du second if

  }else
  if (choix=="jour")
  Valeur2 = Valeur2*15;} 
  else if (choix=="repas"){
  Valeur2 = Valeur2*7;
  document.getElementById("stot2").value = Valeur2+" euros" ;
 }else 
 {valeur2 = 0};
 
 var Valeur3, totalht, tva, totalttc;
 Valeur3 = parseInt(document.getElementById("nombre3").value);
 
 if (isNaN(Valeur3)) { 
         Valeur3 = 0; 
 choix = document.getElementById("resa3").value;
}
 if (choix==='demijour') {
      Valeur3 = Valeur3*8;  
   } // fin du premier if

} // fin du second if
 
  else if (choix=="jour"){
  Valeur3 = Valeur3*15};
  else if (choix=="repas"){
  Valeur3 = Valeur3*7;
  document.getElementById("stot3").value = Valeur3+" euros" ;
 }else 
 {Valeur3 = 0};
 
   


si quelqu un pourrait voir avec des yeux neuf

merci de votre aide
Donnez votre avis

Les membres obtiennent plus de réponses que les utilisateurs anonymes.

Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes.

Le fait d'être membre vous permet d'avoir des options supplémentaires.

Vous n'êtes pas encore membre ?

inscrivez-vous, c'est gratuit et ça prend moins d'une minute !