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 :

Calcul automatique avec ajout de champs de formulaire


Sujet :

JavaScript

Vue hybride

spawns Calcul automatique avec ajout... 23/05/2015, 00h01
SylvainPV Il aurait été plus simple et... 23/05/2015, 12h47
Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de spawns
    Homme Profil pro
    Inscrit en
    Juillet 2004
    Messages
    558
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Gironde (Aquitaine)

    Informations forums :
    Inscription : Juillet 2004
    Messages : 558
    Par défaut Calcul automatique avec ajout de champs de formulaire
    Salut a tous,
    je suis pas un expert en JS et j'essaie de gérer avec des bout de code par si par la.
    voila mon problème.
    j'ai un formulaire auquel je peux ajouter des champs via un script JS, ça cela marche voici le code :
    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
     
      <a href="#" class="add"><button class="btn btn-success">Ajouter</button></a> <a href="#" class="del"><button class="btn btn-danger">Supprimer</button></a>	<br />
    	<form id="myForm" method="post" action="test_envoi.html" >
     
     
          <fieldset>
    		<div class="col-xs-12 col-sm-1 col-md-1 col-lg-1">
    		<label for="qte1"></label>
    		 <input class="form-control" id="qte1" name="qte1" type="text" value="" onblur="calcul()"/>
    		</div>
     
    		<div class="col-xs-12 col-sm-8 col-md-8 col-lg-8">
    		<label for="description1"></label>		
    		 <input class="form-control" id="description1" name="description1" type="text" value="" />
    		</div>
     
    		<div class="col-xs-12 col-sm-1 col-md-1 col-lg-1">
    		<label for="prix1"></label>		
    		 <input class="form-control" id="prix1" name="prix1" type="text" value=""  onblur="calcul()" />
    		</div>
     
    		<div class="col-xs-12 col-sm-1 col-md-1 col-lg-1">
    		<label for="total1"></label>		
    		 <input class="form-control" id="total1" name="total1" type="text" value="" />
    		</div>
     
          </fieldset>
    	  <div class="row">
    		<div class="col-xs-12 col-sm-12 col-md-12 col-lg-12 text-center">	<br />  	  
          <input type="submit" value="Envoyer" />
    	  </div>
    	  </div>
       </form>
    	</div>
       <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js" type="text/javascript"></script>
       <script type="text/javascript">
          $(function(){
     
             var nb = 1;
             $('.add').click(function(){
                var ligneTemp = $(myForm).children("fieldset:last");
                ligneTemp.after(ligneTemp.clone(true));
                $(myForm).children("fieldset:last").hide().fadeIn();
                var ligneTemp = $(myForm).children("fieldset:last");
                ligneTemp.find('label').each(function() {
                   tempLabel = $(this).attr("for").replace(nb, nb+1);
                   $(this).attr("for",tempLabel);
                });
                ligneTemp.find('input').each(function() {
                   this.id= this.id.replace(nb, nb+1);
                   this.name= this.name.replace(nb, nb+1);
                   this.value= "";
                });
                nb++;
             });
             $('.del').click(function(){
                if (nb>1) { // Pour qu'il reste au moins une ligne
                   $(myForm).children("fieldset:last").fadeOut(300, function(){$(this).remove();});
                   nb--;
     
                }
             });
          });
       </script>
    ensuite je voudrais que certains input puisse se calculer, ici "quantité x prix" pour s'afficher dans le input total.
    cela fonctionne avec se petit script
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    <script type="text/javascript">
    function calcul(){
                    var quantite = Number(document.getElementById("qte1").value);
     
                    var prix = Number(document.getElementById("prix1").value);
     
                    var total = Number(quantite * prix);
                    document.getElementById("total1").value = total;
                }
    </script>
    le problème et vous l'avez compris c'est que lorsque j'ajoute des champs mon script de calcul ne fonctionne plus car les id
    des imput ne sont plus les bons.
    a chaque ajout de ligne les ids sont incrementer de +1.
    comment faire pour incrémenter les id des champs dans le script calcul a moins que vous connaissiez une autre solution ?

    Merci d'avance de votre aide
    Cdt

  2. #2
    Rédacteur/Modérateur

    Avatar de SylvainPV
    Profil pro
    Inscrit en
    Novembre 2012
    Messages
    3 375
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2012
    Messages : 3 375
    Par défaut
    Il aurait été plus simple et logique de travailler avec des classes qu'avec des ID (qui par définition identifient de manière unique). Jamais compris pourquoi les gens s'acharnent à utiliser des ID partout.

Discussions similaires

  1. formulaire avec ajout de champs et calcul
    Par bluedreams dans le forum jQuery
    Réponses: 4
    Dernier message: 11/04/2012, 10h34
  2. calcul automatique avec select
    Par maysa dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 07/06/2007, 16h22
  3. net use automatique avec ajout d'un nom au lecteur
    Par Soria17 dans le forum Scripts/Batch
    Réponses: 1
    Dernier message: 20/04/2007, 13h30
  4. Réponses: 7
    Dernier message: 22/08/2006, 16h01
  5. ajouter deux champs..de formulaire
    Par Chronax dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 03/03/2006, 12h15

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