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 :

Div superposés et évenements


Sujet :

JavaScript

  1. #1
    Membre confirmé
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2008
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 504
    Points : 470
    Points
    470
    Par défaut Div superposés et évenements
    Bonjour,

    Voilà, j'ai un problème qui revient assez régulièrement, et je me demandais s'il existait une "bonne façon de faire" pour le contourner.

    Imaginons 2 div en position absolute qui se supperposent :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    <div id="machin" style="position:absolute;width:200px;height:200px;border:1px solid #000;background-color:#FFC;" ondblclick="javascript:alert('machin');" >
     
    	<div id="truc" style="position:absolute;width:50px;height:50px;border:1px solid #000;background-color:#9FC;" ondblclick="javascript:alert('truc');"  >X</div>
     
    </div>
    un double click sur la div du 1er plan va provoquer l'exécution des évènements des 2 div, et donc afficher 2 alertes !

    Existe t-il donc un moyen naturel de ne déclencher que l’évènement du div au 1er plan ?

    En vous remerciant par avance

  2. #2
    Membre expérimenté Avatar de Willpower
    Homme Profil pro
    sans emploi
    Inscrit en
    Décembre 2010
    Messages
    1 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : sans emploi

    Informations forums :
    Inscription : Décembre 2010
    Messages : 1 009
    Points : 1 519
    Points
    1 519
    Par défaut
    déjà enlève les "javascript:" car aucune utilité de label en dehors de boucle.

    ensuite, rajoute un "return false" à la fin des instrusctions pour empécher l’évènement de se propager.


  3. #3
    Membre averti
    Avatar de Darkyl
    Homme Profil pro
    autodidacte en recherche d'emploi
    Inscrit en
    Novembre 2004
    Messages
    440
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Haute Garonne (Midi Pyrénées)

    Informations professionnelles :
    Activité : autodidacte en recherche d'emploi

    Informations forums :
    Inscription : Novembre 2004
    Messages : 440
    Points : 352
    Points
    352
    Billets dans le blog
    1
    Par défaut
    Salut,
    il me semble que dans ta fonction appelé par ton 1er div, à la fin, il suffit de mettre return false;(c'est ce que l'on m'as dit, mais cela n'as jamais marché chez moi )

    Sinon, un truc qui marche bien et qui est propre:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    function click(event)
    {
    event.stopPropagation();
     
    blabla
     
    ...
    }
    A vérifier le event selon les navigateurs, mais moi j'utilise cela et ça marche trés bien.

  4. #4
    Membre confirmé
    Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2008
    Messages
    504
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Décembre 2008
    Messages : 504
    Points : 470
    Points
    470
    Par défaut
    C'est parfait, je me coucherai moins bête ce soir !

    Merci à vous !

  5. #5
    Membre expérimenté Avatar de Willpower
    Homme Profil pro
    sans emploi
    Inscrit en
    Décembre 2010
    Messages
    1 009
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : sans emploi

    Informations forums :
    Inscription : Décembre 2010
    Messages : 1 009
    Points : 1 519
    Points
    1 519
    Par défaut
    Citation Envoyé par Darkyl Voir le message
    Salut,
    il me semble que dans ta fonction appelé par ton 1er div, à la fin, il suffit de mettre return false;(c'est ce que l'on m'as dit, mais cela n'as jamais marché chez moi )
    effectivement, au temps pour moi.

    return false => annule l'action par défaut sur l'élément. (les liens, les submits, etc...)
    stopPropagation (ou cancelBubble pour IE) empêche l'événement de se propager.


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

Discussions similaires

  1. deux div superposés
    Par supcomingenieur dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 04/07/2013, 11h01
  2. Clic() sur DIV superposés
    Par dacid dans le forum jQuery
    Réponses: 5
    Dernier message: 31/05/2011, 16h59
  3. Gérer un même évenement sur des div imbriqués.
    Par snake-09 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 03/02/2010, 16h36
  4. onClick sur deux div superposés
    Par sourivore dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 03/09/2008, 09h27
  5. div non superposés et de taille dynamique
    Par ibtisss dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 07/04/2006, 11h56

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