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 :

Priorité des événements onkeydown


Sujet :

JavaScript

  1. #1
    Membre régulier
    Inscrit en
    Décembre 2008
    Messages
    146
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 146
    Points : 84
    Points
    84
    Par défaut Priorité des événements onkeydown
    Bonjour,

    J'ai un problème à propos des événements onkeydown. Je possède tout d'abord un onkeydown sur un <div>. Pas de soucis, peu importe où je suis dans ma div, il me répond bien. Ensuite dans ce <div>, je crée un élément <span> par exemple avec dedans un lin <a>. Je souhaite rajouter un onkeydown sur mon lien. Et là, le onkeydown du lien n'est jamais pris en compte.

    Code Html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    ...
    <div id="maDiv1" onkeydown="alert('maDiv1');">
    <span>
    <a href="#" name="monLien" onkeydown="alert('monLien');">Clic</a>
    </span>
    </div>
    ...

    Si ce n'était pas assez clair, c'est toujours le alert('maDiv1') qui est déclenché peu importe que je sois sur mon lien ou non.

    Avec la console JS de Chrome, je voit que mon lien possède deux événements onkeydown associés. Celui du <div> et son propre événement.

    Existe-t-il une règle de priorité sur ces types d'événements? Est-ce normal qu'il prenne tout le temps en compte celui de mon <div>? Comment puis-je faire pour que mon onkeydown sur mon lien soit prioritaire?

    Merci d'avance.

  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 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    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 640
    Points : 66 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    cancelbubble et stoppropagation ?

  3. #3
    Membre régulier
    Inscrit en
    Décembre 2008
    Messages
    146
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 146
    Points : 84
    Points
    84
    Par défaut
    Merci pour la réponse. Sauf que je ne maitrise pas ces propriétés.
    J'ai essayé mais sans succès.

    Après mon fonctionnement m'empèche peut-être de mettre en place tout cela.
    J'avais mis en exemple des alert() mais réellement mes onkeydown appellent une seule et même fonction. L'intérêt pour moi de mettre deux fois la gestion de l'événement, est de pouvoir récupérer le target de l'événement. Selon que je suis dans le <div> ou sur mon lien <a> je n'aurais pas le même target. Dans mon cas (sans les propriétés cancelbubble et stoppropagation), mon target est toujours le <div>, puisque que apparemment il prend toujours l'événement parent en priorité.

    Concernant le stoppropagation, je dois le mettre en oeuvre avant l'appel de ma fonction sur le <div> comme ci-dessous?
    Code Html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <div id="maDiv1" onkeydown="if(event.stopPropagation)event.stopPropagation();mafonction();">
    <span>
    <a href="#" name="monLien" onkeydown="mafonction();">Clic</a>
    </span>
    </div>

    ou bien carrément dans mafonction()? ou ailleurs?

  4. #4
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    pour comprendre la différence de fonctionnement avec ou sans stopPropagation
    voici un petit exemple qui construit deux lien le premier sans stop event
    en l'activant et en pressant une touche les deux alertes s'activent
    sur le second avec stopPropagation seule l'alerte du lien s'affiche
    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
    <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
    <html>
      <head>
      <script type="text/javascript">
        function load() {
          var aDiv = document.createElement('div');
          aDiv.onkeydown = function(event) {
            alert('maDiv1');
          };
          aDiv.appendChild(document.createTextNode('before '));
     
          var aLink = aDiv.appendChild(document.createElement('span')).appendChild(document.createElement('a'));
          aLink.setAttribute('name', 'monlien');
          aLink.setAttribute('href', '#');
          aLink.appendChild(document.createTextNode('Clic'));
          aLink.onkeydown = function(event) {
            alert(this.name);
            return false;
          };
          aDiv.appendChild(document.createTextNode(' '));
          aLink = aDiv.appendChild(document.createElement('span')).appendChild(document.createElement('a'));
          aLink.setAttribute('name', 'monlien2');
          aLink.setAttribute('href', '#');
          aLink.appendChild(document.createTextNode('Clic'));
          aLink.onkeydown = function(event) {
            alert(this.name);
            event.stopPropagation();
            return false;
          };
          aDiv.appendChild(document.createTextNode(' after'));
          document.getElementById(1).appendChild(aDiv);
        }
      </script>
      </head>
      <body onload="load()" id=1></body>
    </html>
    A+JYT

  5. #5
    Membre régulier
    Inscrit en
    Décembre 2008
    Messages
    146
    Détails du profil
    Informations forums :
    Inscription : Décembre 2008
    Messages : 146
    Points : 84
    Points
    84
    Par défaut
    Ok merci pour tout!

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

Discussions similaires

  1. Comment régler la priorité des événements ?
    Par leonberg30 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 04/02/2010, 14h02
  2. Définir des priorités aux événements
    Par NoussaL dans le forum VB.NET
    Réponses: 4
    Dernier message: 08/09/2008, 12h37
  3. [C#] Configuration du niveau de priorite des processus
    Par stephdiplo150 dans le forum Windows Forms
    Réponses: 6
    Dernier message: 22/04/2007, 23h29
  4. Créer des événements
    Par thebeb dans le forum MFC
    Réponses: 8
    Dernier message: 04/02/2005, 16h45

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