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 :

Incompréhension sur les événements


Sujet :

JavaScript

  1. #1
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    145
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 145
    Par défaut Incompréhension sur les événements
    Bonjour, besoin d'une petite explication svp.

    Pourquoi si je fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    element.addEventListener('focus',function(){
    console.log('toto');
    });
    la fonction s’exécute bel et bien lorsque cette élément a le focus mais si je fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function toto(){
    	console.log('toto');	
    }
    element.addEventListener('focus',toto());
    La fonction s’exécute dès le chargement de la page.?

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 212
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 212
    Par défaut Le rôle des parenthèses
    Bonjour,
    à partir de cette fonction
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    function show (){
      alert( 'toto');
    }
    ne pas confondre
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var fct = show;  // sans parenthèse
    la variable fct pointe sur le fonction show, un appel à fct() ouvrira une boîte d'alerte avec 'toto' affiché.

    avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    var fct = show();  // avec parenthèses
    où le résultat de la fonction show est affecté à la variable fct, qui vaut dans ce cas undefined, et ce après exécution de la fonction soit ici l'affichage de l'alerte.

    Tu es dans le 2éme cas.

  3. #3
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    145
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 145
    Par défaut
    Merci pour ton intervention,

    Mon problème dans le deuxième cas c'est plutôt le fait que la fonction soit exécutée ( affichage de la boîte de dialogue) alors que l'élément 'element' n'a pas le "focus". chez moi la fonction est exécutée dès chargement de la page et pourtant moi je souhaite l'exécuté quand 'element' a le focus.

  4. #4
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 212
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 212
    Par défaut
    c'est ce que je t'ai indiqué te ne passes pas la référence à la fonction mais le résultat après que la fonction se soit exécutée.

    Mettre les parenthèses après une fonction c'est demander son « exécution ».

    essaies
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    element.addEventListener('focus', toto, false); // ici on a mit la référence à la fonction , son adresse en quelque sorte

  5. #5
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    145
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 145
    Par défaut
    Merci ça fonctionne.

  6. #6
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 212
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 212
    Par défaut
    Que cela fonctionne est une chose mais as tu compris ton erreur ?

  7. #7
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    145
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 145
    Par défaut

    Oui oui, enfin je pense; en gros si je fais
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function toto(){
    		console.log('toto');	
    	}
    	element.addEventListener('focus',toto());
    je passe en paramètre le résultat de l'exécution de la fonction, d'où l'affichage dans ma console au moment de l'exécution
    tandis que :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    function toto(){
    		console.log('toto');	
    	}
    	element.addEventListener('focus',toto);
    je passe en paramètre la référence vers ma fonction qui ne sera exécutée que lorsque mon élément aura le focus.

    enfin passer une fonction anonyme en paramètre a le me comportement que le deuxième cas! exact?

  8. #8
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    17 212
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 212
    Par défaut
    Oui oui,...
    c'est le principal.

    passer une fonction anonyme en paramètre a le me comportement que le deuxième cas! exact?
    oui dans ton code précédent.

    On peut obtenir le même comportement (que ton code #1) en demandant l'exécution immédiate d'une fonction anonyme, voir code #2

    code #1
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    // définition de la fonction
    var fct = function(){
          alert('toto')
    };
    // s'éxécute si l'on écrit
    fct();  // présence des parenthèses
    code #2
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    // définition plus demande exécution immédiate
    var fct = (function(){
          alert('toto')
    })();  // présence des parenthèses

  9. #9
    Membre confirmé
    Homme Profil pro
    Étudiant
    Inscrit en
    Avril 2015
    Messages
    145
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 35
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Avril 2015
    Messages : 145
    Par défaut
    Merci

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

Discussions similaires

  1. Question sur les évènements
    Par Finality dans le forum C#
    Réponses: 3
    Dernier message: 23/12/2008, 23h37
  2. Je débute en haskell, incompréhension sur les classes
    Par NokyDaOne dans le forum Haskell
    Réponses: 6
    Dernier message: 24/08/2008, 21h13
  3. [ppc] Pb sur les évênements KEY_UP.
    Par sylmear dans le forum MFC
    Réponses: 2
    Dernier message: 12/06/2007, 10h39
  4. [C#] Timer sur les évènements des messages Windows
    Par Nullos Oracle dans le forum Windows Forms
    Réponses: 1
    Dernier message: 19/09/2006, 11h33

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