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 :

Pourquoi la position d'1 appel à une fonction diffère en fonction de sa position


Sujet :

JavaScript

  1. #1
    Membre expérimenté
    Profil pro
    Inscrit en
    Mai 2005
    Messages
    3 165
    Détails du profil
    Informations personnelles :
    Localisation : Suisse

    Informations forums :
    Inscription : Mai 2005
    Messages : 3 165
    Par défaut Pourquoi la position d'1 appel à une fonction diffère en fonction de sa position
    Bonjour,
    je suis un peut surpris d'un petit truc

    Dans ma page j'ai ceci:

    entre les balise <head> et </head>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <script language="javascript" src="include/js/rondom_pictures_after_refresh.js"> </script>
    ce code js, conbtient la fonction image aleatoire

    Puis dans ma balise body j'ai ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <body onLoad="init();imagealeatoire()">
    Si je laisse comme ceci ca fonctione très bien

    Par contre si je fait comme ceci
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    <body onLoad="init()">
    <script language="JavaScript">
    	imagealeatoire();
    </script>
    ..... SUite du code...
    Ca marche plus

    Voici ma fonction

    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
     
    function makeArray(n) {
    	this.length = n;
    	for (var i=1; i<=n; i++) {
    		this[i] = ""; 
    	}
    	return this;
    }
     
    //initailise le lien de l'image
    function init(){
    	var ImgLink=document.createElement('a');
    	ImgLink.id='LienImage';
    	ImgLink.href='#';
    	ImgLink.style.textDecoration='none';
    	ImgLink.appendChild(document.getElementById('SlideShow'));
    	document.getElementById('container').appendChild(ImgLink);
    }
     
    var j;
    function imagealeatoire() {
    	j = Math.floor(3 * Math.random() + 1);
     
    	document.getElementById("SlideShow").src = "img/research/"+image[j]+".jpg";
    	document.getElementById('LienImage').href="http://www.domaine.ch?id="+image[j];
    	document.getElementById('sloganTexte').innerHTML = txt[j];
    }
     
    image = new makeArray(3);
    image[1]="30";
    image[2]="18";
    image[3]="24";
     
    txt = new makeArray(3);
    txt[1] ='Analyzing the triggering of landslides using Self-Organized Criticality (SOC)'
    txt[2] ='Sensors development for water content measuring in soil'
    txt[3] ='Evaporation from porous media'
    Le message d'erreur est le suivant
    document.getElementById("SlideShow") has no properties
    [Break on this error] document.getElementById("SlideShow").src = "img/research/"+image[j]+".jpg";
    Mais pourquoi ca marche quand l'appel de la fonction est dans balise <body>, mais elle ne marche plus lorsqu'elle ne l'est plus?????

    En fait, mon petit code marche quand l'appel est dans la balise <body>, mais j'ai remarqué que l'image n'est pas changée forcément a tout le refresh. Des fois y a des "coups blanc". Auriez vous une idée comment optimiser ceci?

    Merci

  2. #2
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 658
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 658
    Billets dans le blog
    1
    Par défaut
    c'est juste une question d'instanciation ...
    l'objet doit être existant sur la page html avec de pouvoir l'appeler avec javascript ...
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

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

Discussions similaires

  1. Position du fichier appelant une méthode
    Par Shudrum dans le forum Langage
    Réponses: 1
    Dernier message: 12/11/2011, 11h59
  2. [DLL] problème pour appeler une fonction d'une DLL
    Par bigboomshakala dans le forum MFC
    Réponses: 34
    Dernier message: 19/07/2004, 11h30
  3. Appeler une fonction avec "action" ds un
    Par drinkmilk dans le forum ASP
    Réponses: 4
    Dernier message: 20/04/2004, 14h54
  4. [JSP] Appeler une fonction
    Par Patrick95 dans le forum Servlets/JSP
    Réponses: 10
    Dernier message: 23/12/2003, 13h44
  5. Appeler une fonction avec/sans parenthèses
    Par haypo dans le forum Algorithmes et structures de données
    Réponses: 8
    Dernier message: 29/12/2002, 18h48

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