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

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  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 207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 207
    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 207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 17 207
    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 207
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

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

+ 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