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 :

Bloquer la propagation d'un evenement


Sujet :

JavaScript

  1. #1
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    234
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 234
    Points : 172
    Points
    172
    Par défaut Bloquer la propagation d'un evenement
    Bonjour,
    Je viens chercher de l'aide.

    Le code suivant me pose problème :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <body onmouseover="alert('Body');">
        <div onmouseover="alert('div');">
    	<div onmouseover="alert('div2');">
    		<label onmouseover="alert('label');">lien1</label>
    		<label onmouseover="alert('label');">lien2</label>
    		<label onmouseover="alert('label');">lien3</label>
    	</div>
    </div>
    </body>

    Lorsque le curseur de la souris passe au dessus du label le onmouseover est propagé à tous les parents :
    s'affiche alors successivement dans des alert 'label','div2','div' et 'body'. Est-il possible de stopper cette propagation ?

  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 637
    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 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    une petite recherche avec cancelBubble ou stopPropagation ...
    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 !

  3. #3
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    234
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 234
    Points : 172
    Points
    172
    Par défaut
    Merci ca me donne un petit indice pour démarrer

  4. #4
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    234
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 234
    Points : 172
    Points
    172
    Par défaut
    Une autre question :
    avec le code suivant :
    <div onmouseover="maFonction()">
    est-il possible de passer l'evenement associé. (celui qui sous IE est dans la variable global window.event) en parametre de la fonction ?

    Merci d'avance

  5. #5
    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 637
    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 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    pour le cancelBubble:
    http://www.developpez.net/forums/sho...t=cancelBubble

    passer l'evènement ? sur le onmouseover ? pas compris
    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 !

  6. #6
    Membre habitué
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    234
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2006
    Messages : 234
    Points : 172
    Points
    172
    Par défaut
    Si tu avais un exemple pour stopper la propagation pour firefox... Ce serait génial !!!

  7. #7
    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 637
    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 637
    Points : 66 661
    Points
    66 661
    Billets dans le blog
    1
    Par défaut
    google is a magic word ...

    http://www.openjs.com/articles/prevent_default_action/

    ou encore :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    function cancel(e)
    {
      if (e && e.preventDefault)
        e.preventDefault(); // DOM style
      return false; // IE style
    }
    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 !

  8. #8
    Expert éminent sénior
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 648
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 648
    Points : 11 137
    Points
    11 137
    Par défaut
    Citation Envoyé par roudoudouduo
    Lorsque le curseur de la souris passe au dessus du label le onmouseover est propagé à tous les parents :
    s'affiche alors successivement dans des alert 'label','div2','div' et 'body'. Est-il possible de stopper cette propagation ?

    Tu peux également jeter un coup d'oeil à cette discussion également (j'utilise une temporisation pour éviter la propagation de l'événement).


    Une autre question :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <div onmouseover="maFonction()">

    est-il possible de passer l'evenement associé. (celui qui sous IE est dans la variable global window.event) en parametre de la fonction ?
    Tout simplement :
    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    <div onmouseover="maFonction(event)">
    valable aussi bien sous IE que sous Firefox (sous IE l'objet window, parent de l'objet event est sous entendu)

Discussions similaires

  1. Propagation d'un evenement personnalisé
    Par ryuhou dans le forum ActionScript 3
    Réponses: 7
    Dernier message: 23/01/2011, 19h15
  2. Réponses: 16
    Dernier message: 04/09/2008, 01h54
  3. Propagation d'un evenement comme une fuite
    Par le merou dans le forum Delphi
    Réponses: 1
    Dernier message: 19/06/2007, 18h01
  4. Stopper la propagation d'un evenement
    Par systemofaxav dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 26/06/2006, 14h41
  5. Réponses: 3
    Dernier message: 24/05/2006, 10h26

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