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 :

Changer une image en fonction d'un compteur


Sujet :

JavaScript

  1. #1
    Candidat au Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2019
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2019
    Messages : 4
    Points : 3
    Points
    3
    Par défaut Changer une image en fonction d'un compteur
    Bonjour,

    j'essaye la même chose... que dans cette discussion.

    je débute totalement en javascript et je voudrais faire en sorte que, quand la valeur de mon input arrive à un certain nombre, l'emoji change : Nom : Image1.png
Affichages : 328
Taille : 13,8 Ko

    Mon 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
    <script>
    	function array(){
    		emojisourire= new Image();
    		emojisourire.src="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f642.svg";
     
    		emojicontent= new Image();
    		emojicontent.src="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f600.svg";
     
    		emojigrandsourire= new Image();
    		emojigrandsourire.src="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60a.svg";
     
    		emojilunettesnoires= new Image();
    		emojilunettesnoires.src="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60e.svg";
     
    		tabEmojis= [emojisourire,emojicontent,emojigrandsourire,emojilunettesnoires];
     
    	function actualiseEmoji()
    	{
    		var compteur = document.getElementById("compteur").value; //récupère la valeur de l'input
     
    		valeur1 = ++i;
    		document.getElementById('compteur').value=document.getElementById("emoji").src;
    	}
    </script>
    <div>
    	<input type="number" id="compteur" min="0" onchange="actualiseEmoji();">
    	<span id="emoji">	</span>
    </div>

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <div>
      <input type="number" id="compteur" value="0" min="0" onchange="actualiseEmoji();">
      <span><img id="emoji" style="width:24px;"/></span>
    </div>
    Code JS : 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
    "use strict";
      // Initialisation des constantes
      const input_compteur = document.getElementById("compteur");
      const img_emoji = document.getElementById("emoji");
      const tab_emojis = [
        "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f642.svg", // 0 : emojisourire
        "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f600.svg", // 1 : emojicontent
        "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60a.svg", // 2 : emojigrandsourire
        "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60e.svg", // 3 : emojilunettesnoires
      ];
      // changement d image en fonction du compteur
      function actualiseEmoji()
      {
        var compteur = input_compteur.value; //récupère la valeur de l'input
        if( compteur < 5 ){
          img_emoji.src = tab_emojis[0];
        } else if( compteur >= 5 && compteur < 10){
          img_emoji.src = tab_emojis[1];
        } else if( compteur >= 10 && compteur < 20){
          img_emoji.src = tab_emojis[2];
        } else if( compteur >= 20){
          img_emoji.src = tab_emojis[3];
        }
      }
      // au chargement
      actualiseEmoji();

    VARIANTE : comme ce ne sont que des icônes, on peut les mettre en background-image du span (sans balise <img/>) :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <div>
      <input type="number" id="compteur" value="0" min="0" onchange="actualiseEmoji();">
      <span id="emoji" style="display:inline-block;width:24px; height:24px;background-size:cover;"/></span> 
    </div>
    Code JS : 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
    "use strict";
    // Initialisation des constantes
    const input_compteur = document.getElementById("compteur");
    const img_emoji = document.getElementById("emoji");
    const tab_emojis = [
      "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f642.svg", // 0 : emojisourire
      "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f600.svg", // 1 : emojicontent
      "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60a.svg", // 2 : emojigrandsourire
      "https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60e.svg", // 3 : emojilunettesnoires
    ];
    // changement d image en fonction du compteur
    function actualiseEmoji()
    {
      var compteur = input_compteur.value; //récupère la valeur de l'input
      if( compteur < 5 ){
        img_emoji.style.backgroundImage = 'url('+tab_emojis[0]+')';
      } else if( compteur >= 5 && compteur < 10){
        img_emoji.style.backgroundImage = 'url('+tab_emojis[1]+')';
      } else if( compteur >= 10 && compteur < 20){
        img_emoji.style.backgroundImage = 'url('+tab_emojis[2]+')';
      } else if( compteur >= 20){
        img_emoji.style.backgroundImage = 'url('+tab_emojis[3]+')';
      }
    }
    // au chargement
    window.onload = actualiseEmoji;
    Dernière modification par Invité ; 10/02/2020 à 12h36.

  3. #3
    Modérateur
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 077
    Points : 17 177
    Points
    17 177
    Par défaut
    Salut
    Une variante, surtout pour le choix de l'index de la variable tableau tabEmojis
    Code HTML : 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
    		<div>
    			<input type="number" id="compteur" min="0" max="20"onchange="actualiseEmoji();">
    			<img id="emoji" src="" height="25px">
    		</div>
    		<script>
                            //*********************************************************************************** 
                    var tabEmojis;
                    creationArray();
     
                    function creationArray(){
                            emojisourire="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f642.svg";
                            emojicontent="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f600.svg";
                            emojigrandsourire="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60a.svg";
                            emojilunettesnoires="https://s.w.org/images/core/emoji/12.0.0-1/svg/1f60e.svg";
                            emojisuper="https://ps.w.org/emoji-in-comments/assets/icon-128x128.png?rev=2164750";
     
                            tabEmojis= [emojisourire,emojicontent,emojigrandsourire,emojilunettesnoires,emojisuper];
                            document.getElementById("compteur").value+0;
                            actualiseEmoji();
                    }
     
                    function actualiseEmoji(){
                            var compteur = document.getElementById("compteur").value; //récupère la valeur de l'input
                            valeur = parseInt(compteur/5);
                            //console.log("valeur = "+valeur);
                            document.getElementById("emoji").src = tabEmojis[valeur];
                    }
            </script>
    Soyez sympa, pensez -y
    Balises[CODE]...[/CODE]
    Balises[CODE=NomDuLangage]...[/CODE] quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Balises[C]...[/C] code intégré dans une phrase.
    Balises[C=NomDuLangage]...[/C] code intégré dans une phrase quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Le bouton en fin de discussion, quand vous avez obtenu l'aide attendue.
    ......... et pourquoi pas, pour remercier, un pour celui/ceux qui vous ont dépannés.
    👉 → → Ma page perso sur DVP ← ← 👈

  4. #4
    Modérateur
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 077
    Points : 17 177
    Points
    17 177
    Par défaut
    Re

    Il me semblait bien avoir fait des essais avec des symboles HTML Unicode
    Code HTML : 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
    		<div>
    			<input type="number" id="compteur" min="0" max="20"onchange="actualiseEmoji();"><span id="emoji" style="font-size:35px"></span>
    		</div>
    		<script>
                            //*********************************************************************************** 
                    var tabEmojis;
                    creationArray();
                    function creationArray(){
                            // source: https://unicode-table.com/fr/blocks/supplemental-symbols-and-pictographs/
                            emojisourire="🤨";
                            emojicontent="🤥";
                            emojigrandsourire="🥺";
                            emojilunettesnoires="🥰";
                            emojisuper="🤩";
     
                            tabEmojis= [emojisourire,emojicontent,emojigrandsourire,emojilunettesnoires,emojisuper];
                            document.getElementById("compteur").value=0;
                            actualiseEmoji();
                    }
                    function actualiseEmoji(){
                            var compteur = document.getElementById("compteur").value; //récupère la valeur de l'input
                            valeur = parseInt(compteur/5);
                            //console.log("valeur = "+valeur);
                            document.getElementById("emoji").innerHTML = tabEmojis[valeur];
                    }
            </script>
    Soyez sympa, pensez -y
    Balises[CODE]...[/CODE]
    Balises[CODE=NomDuLangage]...[/CODE] quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Balises[C]...[/C] code intégré dans une phrase.
    Balises[C=NomDuLangage]...[/C] code intégré dans une phrase quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Le bouton en fin de discussion, quand vous avez obtenu l'aide attendue.
    ......... et pourquoi pas, pour remercier, un pour celui/ceux qui vous ont dépannés.
    👉 → → Ma page perso sur DVP ← ← 👈

  5. #5
    Candidat au Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2019
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2019
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Merci beaucoup Juste un détail : comment faire pour que l'emoji change au défilement sans relâcher la flèche ?

  6. #6
    Modérateur
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 077
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 077
    Points : 17 177
    Points
    17 177
    Par défaut
    Salut

    Remplaces l’événement déclencheur onchange par oninput

    Édit:
    Par contre il faut traiter l'entrée au clavier, donc la fonction actualiseEmoji() devient
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    		function actualiseEmoji(){
    			var compteur = document.getElementById("compteur"); //récupère la valeur de l'input
    			if (compteur.checkValidity() == false || compteur.value === ""){
    				valeur = 5;
    			}else{
    				valeur = parseInt(compteur.value/5);
    			}
    			document.getElementById("emoji").innerHTML = tabEmojis[valeur];
    		}
    Mais aussi ajouter un émoji dans la fonction creationArray()
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    			emojierreur="😈";
     
    			tabEmojis= [emojisourire,emojicontent,emojigrandsourire,emojilunettesnoires,emojisuper,emojierreur];
    Soyez sympa, pensez -y
    Balises[CODE]...[/CODE]
    Balises[CODE=NomDuLangage]...[/CODE] quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Balises[C]...[/C] code intégré dans une phrase.
    Balises[C=NomDuLangage]...[/C] code intégré dans une phrase quand vous mettez du code d'un autre langage que celui du forum ou vous postez.
    Le bouton en fin de discussion, quand vous avez obtenu l'aide attendue.
    ......... et pourquoi pas, pour remercier, un pour celui/ceux qui vous ont dépannés.
    👉 → → Ma page perso sur DVP ← ← 👈

  7. #7
    Candidat au Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2019
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2019
    Messages : 4
    Points : 3
    Points
    3
    Par défaut problème
    Salut, l'emoji ne s'affiche pas...

    Code html : 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
    <div>
    			<input type="number" id="compteur" min="0" max="20"oninput="actualiseEmoji();"><span id="emoji" style="font-size:35px"></span>
    		</div>
    		<script>
                            //*********************************************************************************** 
                    var tabEmojis;
                    creationArray();
                    function creationArray(){
                            // source: https://unicode-table.com/fr/blocks/supplemental-symbols-and-pictographs/
                            emojisourire="🤨";
                            emojicontent="🤥";
                            emojigrandsourire="🥺";
                            emojilunettesnoires="🥰";
                            emojisuper="🤩";
                                                    emojierreur="😈";
                                                    
                            tabEmojis= [emojisourire,emojicontent,emojigrandsourire,emojilunettesnoires,emojisuper,emojierreur];
                            document.getElementById("compteur").value=5;
                            actualiseEmoji();
                    }
                    function actualiseEmoji(){
                            var compteur = document.getElementById("compteur"); //récupère la valeur de l'input
                            if (compteur.checkValidity() == false || compteur.value === ""){
                                    valeur = 5;
                            }else{
                                    valeur = parseInt(compteur.value/5);
                            }
                            document.getElementById("emoji").innerHTML = tabEmojis[valeur];
                    }
                    }
            </script>

  8. #8
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    on t'a donné au moins 4 codes différents.
    A toi de prendre celui que tu comprends.

    En voilà un autre : https://codepen.io/jreaux62/pen/mdJJzmx
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <div>
      <input type="number" id="compteur" min="0" max="20" /><span id="emoji" style="font-size:24px"></span>
    </div>
    Code JS : 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
    "use strict";
    // Initialisation des constantes
    const input_compteur = document.getElementById("compteur");
    const span_emoji = document.getElementById("emoji");
    const tab_emojis = [
      "🙂", // 0
      "😀", // 1
      "😘", // 2
      "😍", // 3
    ];
    // changement d image en fonction du compteur
    function actualiseEmoji()
    {
      var compteur = input_compteur.value; //récupère la valeur de l'input
      if( compteur < 5 ){
        span_emoji.innerHTML = tab_emojis[0];
      } else if( compteur >= 5 && compteur < 10){
        span_emoji.innerHTML = tab_emojis[1];
      } else if( compteur >= 10 && compteur < 20){
        span_emoji.innerHTML = tab_emojis[2];
      } else if( compteur >= 20){
        span_emoji.innerHTML = tab_emojis[3];
      }
    }
    // au chargement
    window.onload = actualiseEmoji;
    input_compteur.addEventListener('input', actualiseEmoji);
    Dernière modification par Invité ; 11/02/2020 à 11h18.

  9. #9
    Candidat au Club
    Homme Profil pro
    Développeur Web
    Inscrit en
    Août 2019
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 26
    Localisation : France, Essonne (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Août 2019
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Celui-ci est parfait !

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

Discussions similaires

  1. Réponses: 1
    Dernier message: 23/11/2006, 16h59
  2. [sockets] gethostbyname retourne toujours la même chose
    Par Strab dans le forum Développement
    Réponses: 3
    Dernier message: 15/09/2006, 10h24
  3. D'autres idées pour faire la même chose ?
    Par Gromitou dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 04/05/2006, 12h15
  4. empecher d'avoir deux fois la même chose dans une listebox
    Par Seb4657 dans le forum Composants VCL
    Réponses: 3
    Dernier message: 25/03/2006, 21h26
  5. Réponses: 12
    Dernier message: 03/03/2006, 11h31

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