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 :

Placer un DIV au-dessus d'un TR


Sujet :

JavaScript

  1. #1
    Rédacteur
    Avatar de Erakis
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2003
    Messages
    523
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Octobre 2003
    Messages : 523
    Points : 233
    Points
    233
    Par défaut Placer un DIV au-dessus d'un TR
    Bonjour à tous

    Je crois que le titre en dit déjà beaucoup...
    Ce que je cherche à faire c'est qu'un DIV ait se placer parfaitement par-dessus (le TR) et ce en ajustant sa taille. Les bordures du DIV ne doivent pas dépasser du TR mais peuvent seulement empiéter vers l'intérieur.

    Alors voilà ce que j'ai :
    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
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    <script>
    // Class permettant de récupérer la position d'un objet
    function GetObjectPosition( obj ) {
        this.Left = 0 ; this.Top = 0;
        if (obj) {
            var objTemp = obj.offsetParent;
            this.Left = obj.offsetLeft;
            this.Top = obj.offsetTop;
            while (objTemp) {
                this.Left = this.Left + objTemp.offsetLeft;
                this.Top = this.Top + objTemp.offsetTop;
                objTemp = objTemp.offsetParent;
            }
         }
         return this;
    }
    
    // Classe permettant de récupérer la taille d'un object
    function GetObjectSize( obj ) {
         this.Width = 0; this.Height = 0;
         if (obj) {
             if (obj.offsetWidth != null) {
                 this.Width = obj.offsetWidth;
                 this.Height = obj.offsetHeight;
             }
         }
         return this;
    }
    
    // Class permettant de déplacer et redimensionner un object
    function MoveAndSizeObject(objRef, left, top, width, height) {
        objRef.style.left = left;
        objRef.style.top = top;
        objRef.style.width = width;
        objRef.style.height = height;
    }
    
    // Lors du chargement du document
    function OnDocuemntLoad() {
       var tableMatrixTR = document.getElementById( "TestTR" );
       var tableMatrixTRDivPosition = new GetObjectPosition( tableMatrixTR );
       var tableMatrixTRDivSize = new GetObjectSize( tableMatrixTR );
    	    
       var testDiv = document.getElementById( "TestDIV" );
       MoveAndSizeObject( testDiv, 
                          tableMatrixTRDivPosition.Left, 
                          tableMatrixTRDivPosition.Top, 
                          tableMatrixTRDivSize.Width, 
                          tableMatrixTRDivSize.Height );
       testDiv.style.visibility = "visible";
    }
    </script>
    
    <style>
    table.TableElem {
    	border-width: 1px;
    	border-spacing: 0px;
    	border-style: groove;
    	border-color: gray;
    	border-collapse: separate;
    	background-color: #fffafa;
    }
    td.CellElem {
    	width :80px;
    	height :80px;
    	border-width: 1px;
    	border-style :dotted ;
    	border-color: black;
    	cursor :default;
    }
    </style>			
    
    <body onload="return OnDocuemntLoad();">
    <div id="TestDIV" style="z-Index :10000; position :absolute; visibility :hidden; border :10px solid red;"></div>
    <table class="TableElem">
      <tr id="TestTR">
        <td class="CellElem">01</td>
        <td class="CellElem">02</td>
        <td class="CellElem">03</td>
      </tr>
      <tr id="TestTR2">
        <td class="CellElem">04</td>
        <td class="CellElem">05</td>
        <td class="CellElem">06</td>
      </tr>
    </table>
    </body>
    Remarquez que le DIV sous IE n'est pas parfaitement juxtaposé au-dessus du TR, et que sur FirexFox c'est encore pire.

    Quelqu'un pourrait me donner un coup de main ?
    Merci

  2. #2
    Rédacteur/Modérateur
    Avatar de troumad
    Homme Profil pro
    Enseignant
    Inscrit en
    Novembre 2003
    Messages
    5 602
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 5 602
    Points : 7 837
    Points
    7 837
    Par défaut
    Sous FF, la raison est simple : la taille ne comprend pas l'épaisseur du bord

    Fais un test avec :
    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
    [...]
       MoveAndSizeObject( testDiv, 
                          tableMatrixTRDivPosition.Left, 
                          tableMatrixTRDivPosition.Top, 
                          tableMatrixTRDivSize.Width-20, 
                          tableMatrixTRDivSize.Height-20 );
       testDiv.style.visibility = "visible";
    }
    </script>
     
    <style>
    table.TableElem {
    	border-width: 10px;
    	border-spacing: 0px;
    [...]

  3. #3
    Rédacteur
    Avatar de Erakis
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2003
    Messages
    523
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Octobre 2003
    Messages : 523
    Points : 233
    Points
    233
    Par défaut
    Citation Envoyé par troumad
    Sous FF, la raison est simple : la taille ne comprend pas l'épaisseur du bord

    Fais un test avec :
    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
    [...]
       MoveAndSizeObject( testDiv, 
                          tableMatrixTRDivPosition.Left, 
                          tableMatrixTRDivPosition.Top, 
                          tableMatrixTRDivSize.Width-20, 
                          tableMatrixTRDivSize.Height-20 );
       testDiv.style.visibility = "visible";
    }
    </script>
     
    <style>
    table.TableElem {
    	border-width: 10px;
    	border-spacing: 0px;
    [...]
    Pour Firefox cela fonctionne très bien et je vous en remerci beaucoup.

    Cependant, pour IE il semble y avoir un problème de 1 ou 2 px en de décalage. Essayez et vous verrez
    Donc, comment avec IE, régler ce problème ?

    Merci

  4. #4
    Rédacteur/Modérateur
    Avatar de troumad
    Homme Profil pro
    Enseignant
    Inscrit en
    Novembre 2003
    Messages
    5 602
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Enseignant
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2003
    Messages : 5 602
    Points : 7 837
    Points
    7 837
    Par défaut
    Je n'ai pas IE sur mon PC que je préserve de tous virus Microsoft...

  5. #5
    Rédacteur
    Avatar de Erakis
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2003
    Messages
    523
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Octobre 2003
    Messages : 523
    Points : 233
    Points
    233
    Par défaut
    Me voilà bien avancé avec cette réponse

    Toutefois, merci de ton aide troumad.
    Quelqu'un d'autre pour m'expliquer ce qui ne fonctionne pas avec IE ?

  6. #6
    Rédacteur
    Avatar de Erakis
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2003
    Messages
    523
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : Canada

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Électronique et micro-électronique

    Informations forums :
    Inscription : Octobre 2003
    Messages : 523
    Points : 233
    Points
    233
    Par défaut
    En cherchant encore sur Google, je viens de remarquer que cela peut d'épendre du doctype du document. Mais encorè la, peut importe le doctype que je met, les browsers agissent encore très différemment, résultat le DIV ne se place pas correctement.

Discussions similaires

  1. Placer 2 DIV l'un à coté de l'autre
    Par Royd938 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 06/10/2005, 10h36
  2. div par dessus scrollbar
    Par zizou771 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 29/08/2005, 11h02
  3. placer 2 DIV l'un à côté de l'autre
    Par Ekimasu dans le forum Balisage (X)HTML et validation W3C
    Réponses: 7
    Dernier message: 15/03/2005, 11h18
  4. [W3C] Est-il possible d'afficher un div par dessus une applet ?
    Par drinkmilk dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 23/02/2005, 10h22
  5. Réponses: 14
    Dernier message: 08/01/2005, 16h53

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