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 :

[DOM] blockage d'un <div> par z-index


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 7
    Par défaut [DOM] blockage d'un <div> par z-index
    Bonjour,

    J'ai cassé ma tête pendant 2 jours maintenat sur ce sujet...

    J'aimerais trouver une cross-browser solution pour empêcher toute détection des differents elements par mouseover, mouseout et autre sauf celles concernant le <div>-container.

    Exemple structure:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <div id="topcontainer">
    <div id="contenu1">
    /*tableau mixte avec textes, liens et images*/
    </div>
    <div id="contenu2">
    /*tableau mixte avec textes, liens et images*/
    </div>
    </div>
    Problême: Une "onmouseover" pour topcontainer par exemple se déclenche à chaque survol d'un element présent dans ce <div>.

    Pour une bonne fonctionnement j'ai besoin d'une déclenchement uniquement à partir de l'extérieur du topcontainer et non pas quand le pointeur se trouve déja sur topcontaineur mais commence de survoler une élément enfant.

    merci d'avance,

    Martin

  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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    a part une focntion qui testerait tous les parents jusqu'au body pour vois si il a un id topcontainer genre while this.ParentNode.id!='topcontainer ...
    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
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 7
    Par défaut
    Merci SpaceFrog

    Citation Envoyé par SpaceFrog
    a part une focntion qui testerait tous les parents jusqu'au body pour vois si il a un id topcontainer genre while this.ParentNode.id!='topcontainer ...
    Sans fontion, Avec IE, j'avais déja obtenu une fonctionnement souhaitée avec contenu1 et contenu2 en z-index: -1 et une div supplementaire (position:relative) superposé en z-index 0 ou sup. (ne marche pas avec p.a. topcontainer z-index:1 et masque en z-index:2):

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <div id="topcontainer" style="position:relative;z-index:-1;height:100px"> 
    <div id="contenu1">
    /*tableau mixte avec textes, liens et images*/
    </div>
    <div id="contenu2">
    /*tableau mixte avec textes, liens et images*/
    </div>
    </div>
    <div id="masque" style="position:relative;z-index:1;top:-100px;height:100px;">
    Malheureusement ça ne marche pas avec Firefox; "topcontainer", "contenu1" et "contenu2" sont invisiblement masqués par "masque".
    Avec Firefox ça marche uniquement avec "topcontainer" et "masque" au meme z-index (obligatoirement 0 ou positive).
    Firefox semble de cacher tout élement en z-index négatif).

    Es-ce-qu'on pourrait trouver la solution dans ce sens là aussi?

    Merci, Martin

  4. #4
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2003
    Messages
    109
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2003
    Messages : 109
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    function(evt){
        if(evt){//DOM
            if(evt.target.id!='topcontainer') evt.stopPropagation()
        }else{//IE
            if(window.event.relatedTarget.id!='topcontainer') window.event.cancelBubble = true
        }
    }
    Pour la partie IE, je suis pas sur.

  5. #5
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 7
    Par défaut
    merci Macintoc,

    Je vais essayer cette solution. En plus, je viens de découvrir un autre discussion comparable sur ce forum: http://www.developpez.net/forums/sho...d.php?t=267283

    a+

  6. #6
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2007
    Messages
    7
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2007
    Messages : 7
    Par défaut
    Inspiré par l'autre thread, j'ai pu developper ceci:

    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
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
     
    <html>
    <head>
    <title></title>
     
    <script type="text/javascript">
    <!--
    var timer = null;
    var i = 0;
    var c = new Array();
    var open_div = "";
     
    function fover(ref)
    {
      i=i+1;
      c[i] = ref.getAttribute('id');
      if (c[i-1]) { /*déja une div détecté*/
    	 prec_c = document.getElementById(c[i-1]);
    	 prec_c_id = prec_c.getAttribute('id');
    	 if(c[i] != prec_c) {
    		prec_c.childNodes[1].style.height = "0px";
    		ref.childNodes[1].style.height = "100px";
    		open_div = ref.childNodes[1].getAttribute('id');
    	}
      }
    }
    //-->
    </script>
     
    </head>
     
    <body>
     
    <div style="border: 1px solid #AAAAAA" id="Div1" onmouseover="fover(this)">
     <div id="container1-0" >titre 1</div>
     <div id="container1-1" style="height:0px">
      <table id="tableau" border="1" cellspacing="0" cellpadding="0" >
      <tr>
      <td>&nbsp;bla bla bla</td>
      <td>&nbsp;bla bla bla</td>
      <td>&nbsp;bla bla bla</td>
      </tr>
      </table>
     </div>
    </div><br>
    <div style="border: 1px solid #AAAAAA" id="Div2" onmouseover="fover(this)">
     <div id="container2-0">titre 2</div>
     <div id="container2-1" style="height:0px">
      <table border="1" cellspacing="0" cellpadding="0" >
      <tr>
      <td>&nbsp;bla bla bla</td>
      <td>&nbsp;bla bla bla</td>
      <td>&nbsp;bla bla bla</td>
      </tr>
      </table>
     </div>
    </div>
     
    </body>
     
    </html>
    ceci marche bien pour IE mais pas trop pour Firefox
    En plus, je cherche une moyen de fermer le dernier container ouvert si le pointeur ce trouve ni sur un autre container , ni sur le dernier...


    Martin

Discussions similaires

  1. hauteur <div> automatique par rapport à un autre <div>
    Par arnaud_verlaine dans le forum Mise en page CSS
    Réponses: 11
    Dernier message: 08/05/2008, 19h38
  2. [DOM] php4 : validation d'un fichier XML par rapport à un XSD
    Par nannous dans le forum Bibliothèques et frameworks
    Réponses: 4
    Dernier message: 25/02/2008, 09h43
  3. [AJAX] Div modifié par Ajax ne s'affiche qu'une seconde
    Par dream_of_australia dans le forum Général JavaScript
    Réponses: 12
    Dernier message: 27/06/2007, 08h50
  4. [DOM] Ajouter contenu dynamiquement dans div en javascript
    Par kalan dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 10/11/2006, 11h06
  5. <div> à envoyer par echo
    Par Jean_Benoit dans le forum Langage
    Réponses: 5
    Dernier message: 19/02/2006, 18h30

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