Partage
  • Partager sur Facebook
  • Partager sur Twitter

Essaye d'appliquer un script sur plusieurs boutons

mon javascript s'applique sur un seul bouton alors qu'ils sont pareils

Sujet résolu
    3 février 2023 à 19:54:37

    Bonjour;
    Mon javascript s'applique sur un seul bouton alors qu'ils sont pareils( le premier seulement ) , j'ai cherché comment régler ce probleme mais j'ai rien trouvé 
    ( Le javascript c pas mon point fort xD c'est la première fois que je l'utilise)
    voilà le script html 
    <div class="container devinettes">
    	<div class="col-sm-12">
    		
    			<div class="p-2 mb-2">
    			<h5>Le père de Tom a trois fils : Jim, John, et quel est le nom du troisième ?</h5><br>
    			<button class="solution" ><h5>Voir la réponse</h5></button>
    				<div class="reponse cache">
    				<h4>TOM</h4>
    				</div>
    				<script src="script5.js"></script>
    			</div>
    		</div>
    	</div>
    </div><br><br>
    
    <div class="container devinettes">
        <div class="col-sm-12">
            
                <div class="p-2 mb-2">
                <h5>Le père de Tom a trois fils : Jim, John, et quel est le nom du troisième ?</h5><br>
                <button class="solution" ><h5>Voir la réponse</h5></button>
                    <div class="reponse cache">
                    <h4>TOM</h4>
                    </div>
                    <script src="script5.js"></script>
                </div>
            </div>
        </div>
    </div><br>
    et pour le javascript
    const btnShow = document.querySelector(".solution");
    const answer = document.querySelector(".reponse");
    
    const clickBtn = function () {
      if (answer.classList.toggle("cache")) {
        btnShow.textContent = "Voir la réponse";
      } else {
        btnShow.textContent = "Cacher la réponse";
      }
    };
    
    btnShow.addEventListener("click", clickBtn);
    
    et voilà le css ( meme si jsp si c lui ou il ya le probleme )
    div.container div.col-sm-12 div.cache {
      display: none;
      margin: auto;
    }
    
    div.container div.col-sm-12 div.reponse {
      width: 700px;
      padding: 20px 0;
    }
    
    
    div.container div.col-sm-12 h5{
    	text-align: center;
    }
    div.container div.col-sm-12 button.solution {
      display: inline-block;
      margin-top: 20px;
      font-size: 15px;
      cursor: pointer;
      border: none;
      border-radius: 8px;
      padding: 10px;
      background-color: #ff6e40;
      color: #0d1137;
      box-shadow: 0 20px 30px 0 rgba(0, 0, 0, 0.07);
      display: block;
      margin: auto;
      font-weight: bold;
    }
    div.devinettes{
    	border: solid;
    	border-radius: 15px;
    	border-width: 2px;
    	border-color: steelblue;
    }
    

    D'avance je vous remercie pour votre aide! 

    Youssef

    -
    Edité par youssefgaming209 3 février 2023 à 21:42:15

    • Partager sur Facebook
    • Partager sur Twitter
      3 février 2023 à 20:43:27

      Hello,

      querySelector ne prends qu'un seul élément, il faut utiliser querySelectorAll pour prendre tous :

      https://developer.mozilla.org/fr/docs/Web/API/Document/querySelectorAll

      • Partager sur Facebook
      • Partager sur Twitter
        3 février 2023 à 20:50:26

        Bonjour,

        J'ai changé querySelector en querySelectorAll mais cette fois meme le premier bouton ne marche plus

        const btnShow = document.querySelectorAll(".solution");
        const answer = document.querySelectorAll(".reponse");
         
        const clickBtn = function () {
          if (answer.classList.toggle("cache")) {
            btnShow.textContent = "Voir la réponse";
          } else {
            btnShow.textContent = "Cacher la réponse";
          }
        };
         
        btnShow.addEventListener("click", clickBtn);
        

        -
        Edité par youssefgaming209 3 février 2023 à 20:50:38

        • Partager sur Facebook
        • Partager sur Twitter
          3 février 2023 à 21:00:00

          Tu as regarder la doc que j'ai mis en lien ?

          Il faut que tu boucle sur chaque élément :

          const buttons = document.querySelectorAll(".button");
          
          buttons.forEach(function(btn) {
            btn.addEventListener('click', function () {})
          });



          • Partager sur Facebook
          • Partager sur Twitter
            3 février 2023 à 21:10:49

            Je comprend pas trop là ( c'est ma toute première fois en javascript ), jsp comment l'appliquer

            Tu peux l'appliquer sur mon script et me l'envoyer stp ?

            ps: j'ai rej ton discord

            -
            Edité par youssefgaming209 3 février 2023 à 21:11:41

            • Partager sur Facebook
            • Partager sur Twitter
              3 février 2023 à 21:28:59

              Bonjour,

              Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
              Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

              Pour plus d'informations, nous vous invitons à lire les règles générales du forum

              Mauvais titre

              Le titre est un élément important qui ne doit pas être négligé. N'oubliez pas cette règle simple : le titre idéal résume la question que vous allez poser en une petite phrase. Il doit permettre aux visiteurs de se repérer facilement dans le forum visité et d'identifier le sujet à sa seule lecture.

              Vous pouvez utiliser divers préfixes comme [Erreur], [MySQL], [Compatibilité], etc... Aussi, pensez à consulter les règles propres à chaque forum (visibles dans les topics épinglés en haut des sections).

              De plus, choisir un bon titre permet de rendre plus faciles les recherches des autres membres.

              Les titres de type "besoin d'aide" ou "problème" ne sont pas tolérés.

              Merci de modifier votre titre. Pour cela, éditez le premier message de votre sujet.

              (titre originel : Probleme d'execution javasctipt)

              • Partager sur Facebook
              • Partager sur Twitter

              Pas d'aide concernant le code par MP, le forum est là pour ça :)

                4 février 2023 à 6:31:55

                Bonjour, tu n'as pas besoin d'ajouter plusieurs fois ton même script dans le documents.

                Tu devrais appeler une seule fois ton fichier Javascript.

                Ton fichier Javascript devrait sélectionner tous les boutons (avec la façon que ta montré quenti77)

                Puis il devrait parcourir tous les boutons pour ajouter un écouteur de clique sur chacun d'entre eux.

                Si c'est système de callback qui est utilisé pour parcourir les boutons qui te perturbe (c'est un système propre à Javascript donc si tu viens d'un autre langage ça peut sembler assez spéciale).

                Tu peux remplacer la boucle forEach:

                buttons.forEach(function(btn) {
                  btn.addEventListener('click', function () {})
                });

                Par une boucle plus "traditionnelle" comme la boucle for...of

                // parcour tous les bouttons:
                // pour chaque boutton (button) de la liste de boutons (buttons)
                for(const button of buttons) {
                	
                    // ajoute un écouteur d'événement au bouton qui est actuellement parcouru (button)    
                    button.addEventListener("click", function () {
                    
                    	// ...
                        // ...
                
                	})
                }

                Le problème que tu peux rencontrer actuellement c'est que rien ne vient faire la liaison entre un bouton et la réponse qui lui est associé.

                Une façon de faire la liaison serait d'ajouter des attributs data-* tel que:

                <!-- ... -->
                <!-- ... -->
                
                <button class="solution" data-answer-id="0">
                	<h5>Voir la réponse</h5>
                </button>
                <div data-answer-id="0" class="reponse cache">
                	<h4>TOM</h4>
                </div>
                
                <!-- ... -->
                <!-- ... -->
                
                <button class="solution" data-answer-id="1">
                	<h5>Voir la réponse</h5>
                </button>
                <div class="reponse cache" data-answer-id="1">
                	<h4>TOM</h4>
                </div>
                
                <!-- ... -->
                <!-- ... -->

                Ci-dessus je repris un extrait de ton HTML (les boutons, et les réponses) et elles sont associé via un attribut data-answer-id,

                qui est un nom arbitraire.

                Un script qui illustre une manière plus complète de faire pourrait être:

                <script>
                // séléctionne tous les bouttons qui contienne une classe "solution"
                const btnShowList = document.querySelectorAll("button.solution");
                
                
                // parcour tous les bouttons:
                // pour chaque boutton (btnShow) de la liste de bouttons (btnShowList)
                for(const btnShow of btnShowList) {
                	
                    // ajoute un écouteur d'événement au boutton qui est actuellement parcouru (btnShow)    
                    btnShow.addEventListener("click", function () {
                    
                    	// récupére l'id de la réponse:
                        const id = this.getAttribute("data-answer-id") // this faisant référence au bouton qui a était cliqué
                        
                        // séléctionne la réponse associé a ce bouton, en se basant sur l'attribut "data-answer-id"
                        const answer = document.querySelector(`div[data-answer-id="${id}"]`)
                        
                        // change l'état de visiblité de la réponse:
                        if (answer.classList.toggle("cache")) {
                            this.textContent = "Voir la réponse";
                        } else {
                            this.textContent = "Cacher la réponse";
                        }
                
                	})
                }
                </script>






                • Partager sur Facebook
                • Partager sur Twitter

                suggestion de présentation.

                Essaye d'appliquer un script sur plusieurs boutons

                × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
                × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
                • Editeur
                • Markdown