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 :

Problème dans un script


Sujet :

JavaScript

  1. #1
    Membre régulier
    Inscrit en
    Avril 2007
    Messages
    233
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2007
    Messages : 233
    Points : 94
    Points
    94
    Par défaut Problème dans un script
    Salut tout le monde,

    mon code est le suivant:

    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
     
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Document sans nom</title>
    <script type="text/javascript">
    var tabElem=Array("btn_val_etp.gif","asso_etp.gif");
    var tabDelay=Array(2000,4000);
    var index=0;
     
    function pub(index)
    {
    	if(index>=tabElem.length) index=0;
    	if(tabElem.length>1)
    	{	document.getElementById("pub").innerHTML="<IMG WIDTH=250 HEIGHT=100 SRC="+tabElem[index]+">";
    		index++;
    		setInterval(pub(index),tabDelay[index-1]);
    	}
    }
    </script>
    </head>
     
    <body onload="pub(0)">
    <div id="pub" style="width:300px; height:250px;"></div>
    </body>
    </html>
    Le principe c'est que chaque image à un compteur précis, et je veux que ces images s'affichent l'une après l'autre suivant le compteur, mais le problème c'est que ça m'affiche que le 1er élément du tableau sans qu'il passe au 2ème, le code me parai logique!!!!

  2. #2
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Bonjour,
    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
    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>Document sans nom</title>
    <script type="text/javascript">
    var tabElem=Array("next.gif","prev.gif");
    var tabDelay=Array(2000,4000);
    var index=0;
    
    function pub()
    {
    	if(index>=tabElem.length) index=0;
    	if(tabElem.length>1)
    	{	document.getElementById("img_pub").src=tabElem[index];
    		index++;
    		setTimeout("pub()",tabDelay[index-1]);
    	}
    }
    </script>
    </head>
    
    <body onload="pub()">
    <div id="pub" style="width:300px; height:250px;"><IMG id="img_pub" WIDTH=250 HEIGHT=100 SRC=''></div>
    </body>
    </html>
    Remarques (dans le désordre) :
    • Tu utilisais un setInterval dans un appel récursif => setTimeout()
    • dans ces 2 fonctions, le 1° paramètre est une chaine de car. (et non la référence à la fonction)
    • Tu passais "index" en paramètre alors que c'est une variable globale => problème de portée de la variable
    • le innerHTML doit être réservé au texte sans balise, or tu regénérais à chaque fois le tag <img> => mieux vaut créer le tag "en dur" puis ne modifier que son src via le script

    EDIT : version ci-dessus testée avec IE6 et FF2

    A+

  3. #3
    Membre régulier
    Inscrit en
    Avril 2007
    Messages
    233
    Détails du profil
    Informations personnelles :
    Âge : 39

    Informations forums :
    Inscription : Avril 2007
    Messages : 233
    Points : 94
    Points
    94
    Par défaut
    Merci beaucoup E.buzz ça marche parfaitement

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

Discussions similaires

  1. problème dans un script d'un bouton
    Par sky88 dans le forum VBScript
    Réponses: 4
    Dernier message: 02/06/2009, 10h02
  2. [MySQL] Problème dans mon script
    Par ceetix dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 15/10/2007, 19h06
  3. [PHP-JS] problème dans mon script
    Par kawther dans le forum Langage
    Réponses: 2
    Dernier message: 17/04/2007, 08h57
  4. problème dans mon script
    Par kawther dans le forum Langage
    Réponses: 1
    Dernier message: 21/03/2007, 16h40
  5. [MySQL] Problème dans mon script de pagination
    Par speedylol dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 03/11/2005, 19h37

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