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 :

OnMouseOver => Position Element


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Août 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Août 2006
    Messages : 45
    Par défaut OnMouseOver => Position Element
    Bonjour a tous,

    Je suis confronter a un petit probleme dont je comprends les raisons mais dont je ne sais pas comment le resoudre.
    Mon site web possede sur la partie de gauche un menu dynamique, c'est a dire que tous mes liens sont susceptibles de changer d'ordre.
    Le truc, c'est que un des liens (de type BLOCK avec une hauteur de 20px) affiche en mouseover un menu en position:absolute.
    J'ai recupere la position de la souris au survol de ce lien et j'affiche donc mon sous-menu par rapport a la position en y.
    Mais le probleme est que mon lien fait 20px de hauteur, donc l'affichage de mon sous-menu varie de 20 px en fonction de si je survole le lien en venant du bas ou si je le survole en partant du haut.

    Je crois que le meilleur moyen serait de recuperer la position de l'emplacement
    de mon lien, mais cela est-il vraiment faisable???

    Code du lien mis en cause :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="" id="linkbox" onMouseOver="montre(\'smenu2\',event)" onmouseout= "delai()">'.$rowmenu[1].'</a>
    Javascript :
    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
    function montre(id,e)
     {
     
    var d = document.getElementById(id);
    clearTimeout(timeout)
    for (var i = 1; i<=10; i++) 
    {
    	if (document.getElementById('smenu'+i)) {document.getElementById('smenu'+i).style.display='none';}
    }
    if (d) 
    {
    d.style.display='block';
    	if(e)
    	{
    		height=getposition(e);
    		d.style.marginTop=height;
    	}
    }
     
    }
     
    function getposition(e) {
    y = (navigator.appName.substring(0,3) == "Net") ? e.pageY : event.y+document.body.scrollTop;
    if (navigator.appName.substring(0,3) != "Net") y=y+100;
    return y;
    }
    Merci d'avance pour vos suggestions

  2. #2
    Membre averti
    Inscrit en
    Août 2006
    Messages
    45
    Détails du profil
    Informations personnelles :
    Âge : 40

    Informations forums :
    Inscription : Août 2006
    Messages : 45
    Par défaut
    Comme souvent, quand on poste son probleme, on trouve la solution par soi meme.
    Alors j'ai fini par realiser un Id unique pour ce lien, que je recupere ainsi en javascript et j'obtiens la hauteur de cet element avec un offsterTop. Probleme resolu !!!

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

Discussions similaires

  1. Comment faire afficher la position d'un element dans un tableau
    Par IDE dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 04/11/2006, 12h44
  2. Réponses: 3
    Dernier message: 20/09/2006, 16h48
  3. evenement onmouseover sur element HTML disabled
    Par danyboy85 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 2
    Dernier message: 05/04/2006, 12h04
  4. [XSLT]position d'un element de valeur specifique
    Par squat dans le forum XSL/XSLT/XPATH
    Réponses: 6
    Dernier message: 25/07/2002, 16h42

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