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 :

Positionner un <div> par rapport à une ancre


Sujet :

JavaScript

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    100
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 100
    Points : 48
    Points
    48
    Par défaut Positionner un <div> par rapport à une ancre
    Bonjour,

    Je viens de tester cette solution qui fonctionne parfaitement sous IE. http://www.devparadise.com/technoweb...cript/a326.php

    Sous FF le <DIV> s'affiche mais n'est pas à la bonne place. Sous opéra il ne s'affiche même pas.

    Quelqu'un aurait-il une idée au moins pour FF ou même une autre solution?

    Merci,

  2. #2
    Membre confirmé Avatar de nounetmasque
    Inscrit en
    Janvier 2003
    Messages
    494
    Détails du profil
    Informations forums :
    Inscription : Janvier 2003
    Messages : 494
    Points : 570
    Points
    570
    Par défaut
    Hum un exemple de code à nous fournir pour tester directement sans se farcir tout le tutoriel ?

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2004
    Messages
    100
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2004
    Messages : 100
    Points : 48
    Points
    48
    Par défaut
    Bonjour,

    Voici le code (Le lien donné affiche directement le code)

    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
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
     
    <SCRIPT>
    <!--
    var ns4 = (document.layers)? true:false;   //NS 4 
    var ie4 = (document.all)? true:false;   //IE 4 
    var dom = (document.getElementById)? true:false;   //DOM 
     
     
    function setToAnchor(ID_Anchor,Name_Anchor,ID_Div)
    //Fonction permettant de positionner un DIV à une position occupée par une ancre
        {
    var DivLeft = 0;   //Position du Div par rapport au côté gauche de la page 
    var DivTop = 0;   //Position du Div par rapport au haut de la page 
        if (dom)
            {
            pos = document.getElementById(ID_Anchor);
            DivLeft = getLeft(pos);
            DivTop = getTop(pos);
            document.getElementById(ID_Div).style.left = DivLeft;
            document.getElementById(ID_Div).style.top = DivTop;
            }
        else if (ie4) 
            {
            pos = document.all[ID_Anchor];
            DivLeft = getLeft(pos);
            DivTop = getTop(pos);
            document.all[ID_Div].style.posLeft = DivLeft;
            document.all[ID_Div].style.posTop = DivTop;
            }
        else if (ns4)
            {
            pos = document.anchors[Name_Anchor];
            DivLeft = pos.x;
            DivTop = pos.y;
            document.layers[ID_Div].pageX = DivLeft;
            document.layers[ID_Div].pageY = DivTop;
            }
        }
     
    function getLeft(MyObject)
    //Fonction permettant de connaître la position d'un objet
    //par rapport au bord gauche de la page.
    //Cet objet peut être à l'intérieur d'un autre objet.
        {
        if (MyObject.offsetParent)
            return (MyObject.offsetLeft + getLeft(MyObject.offsetParent));
        else 
            return (MyObject.offsetLeft);
        } 
    function getTop(MyObject)
    //Fonction permettant de connaître la position d'un objet
    //par rapport au bord haut de la page.
    //Cet objet peut être à l'intérieur d'un autre objet.
        {
        if (MyObject.offsetParent)
            return (MyObject.offsetTop + getTop(MyObject.offsetParent));
        else
            return (MyObject.offsetTop);
        }
    //-->
    </SCRIPT>
     
     
    Ensuite, déclarez le tag body suivant :
     
    <BODY OnLoad="setToAnchor('id_ancre','nom_ancre','MonDiv')">
     
     
    Après, déclarez où vous voulez dans votre page HTML le DIV que vous voulez placer :
     
    <DIV id="MonDiv" style="position:absolute;visibility:visible;">
    Le Contenu de mon div...
    </DIV>
     
     
    Et enfin, à l'endroit où vous voulez placer votre DIV, déclarez l'ancre :
     
    <A id="id_ancre" name="nom_ancre">&nbsp;</A>

Discussions similaires

  1. Adapter la taille d'une DIV par rapport à une autre
    Par sletis dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 23/03/2009, 17h41
  2. Positionnement de la souris par rapport à une image et ascenseur !
    Par flyxter dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 04/09/2008, 23h45
  3. Comment positionner une div par rapport à une autre
    Par solorac dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 17/07/2008, 21h08
  4. positionnement de texte par rapport à une image
    Par maysa dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 03/12/2007, 13h49
  5. Réponses: 6
    Dernier message: 10/04/2007, 15h14

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