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

Mise en page CSS Discussion :

Décalage d'une image et d'un titre alors qu'ils ont la même marge


Sujet :

CSS

  1. #1
    Membre régulier
    Inscrit en
    Juillet 2004
    Messages
    306
    Détails du profil
    Informations forums :
    Inscription : Juillet 2004
    Messages : 306
    Points : 122
    Points
    122
    Par défaut Décalage d'une image et d'un titre alors qu'ils ont la même marge
    Bonsoir,

    je débute en CSS et je rencontre quelques difficultés pour appliquer des marges à une image et un titre H1 alignés verticalement.
    J'ai appliqué la même marge haute à l'image et au titre, pourtant l'image est plus bas que le titre. (Voir Screenshot_1.jpg)

    Voici le code html:

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    <body>
        <div id="bandeau">
            <img src="http://www.developpez.net/template/images/logo.gif" border="0" alt=""/>
            <h1 class="TexteEnTete">Titre1</h1>
        </div>
        <form id="form1" runat="server">
            <asp:ContentPlaceHolder ID="MainContent" runat="server">
                <h2>Texte</h2>
            </asp:ContentPlaceHolder>
        </form>
    </body>

    et le code CSS:

    Code css : 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
    #bandeau
    {
        border-style: none;
        border-width: thin;
        border-color: Black;
    }
     
    #bandeau img 
    {
        float : left;
     
        margin-top: 10px;
        margin-left: 20px;
    }
     
    #bandeau .TexteEnTete{
      color: #FFFFFF;
      font-size: 200%;
      font-weight: normal;
      font-style: italic;
     
      text-align: right;
      padding-right: 2%;
     
      vertical-align : middle;
      line-height : 90px;
     
      margin-top: 10px;
      margin-left: 275px;
      margin-right: 20px;
     
      background: #008689;
    }

    Curieusement, si j'ajoute une bordure à l'id bandeau, l'image est correctement alignée par rapport au titre. (Voir Screenshot_2.jpg)

    Code css : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    #bandeau
    {
        border-style: solid;
        border-width: thin;
        border-color: Black;
    }

    Bref, je ne comprends pas trop l'origine du problème.
    D'où ça vient d'après vous ?

    Merci d'avance
    Etienne
    Images attachées Images attachées   

  2. #2
    Membre régulier
    Profil pro
    Développeur Web
    Inscrit en
    Octobre 2010
    Messages
    153
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Octobre 2010
    Messages : 153
    Points : 107
    Points
    107
    Par défaut
    Salut,
    si tu rajoute
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    background-color:yellow;
    à ton bandeau tu verra que le h1 n'est pas du tout décalé de 10px en haut du div, alors que l'image est bien décalée.

    Je pense que le calcul de la marge pour le h1 est pris sur la base du div seulement si celui-ci a une bordure. Sinon c'est pris sur l'élément parent, ici la bordure de page.
    Si tu augmente le margin-top du h1 seul, ça décale en effet tout le div.

    Je te conseil d'enlever les margin-top de #bandeau img et #bandeau .TexteEnTete et de le placer dans #bandeau et là ça marche.
    Par contre lorsque tu appliques une bordure, ça décale dans l'autre sens. Pour éviter ça il faut mettre margin-top à 0 pour le h1.

    En clair :
    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
      #bandeau
    {
        border-style: none;
        border-width: thin;
        border-color: Black;
    	background-color:yellow;
        margin-top: 10px;
    }
     
    #bandeau img 
    {
        float : left;
        margin-left: 20px;
    }
    #bandeau .TexteEnTete{
      color: #FFFFFF;
      font-size: 200%;
      font-weight: normal;
      font-style: italic;
     
      text-align: right;
      padding-right: 2%;
     
      vertical-align : middle;
      line-height : 90px;
     
      margin-top:0;
      margin-left: 275px;
      margin-right: 20px;
     
      background: #008689;
    }
    Dis-moi si ça roule

Discussions similaires

  1. Décalage d'une image selon la résolution
    Par camox dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 29/07/2013, 21h23
  2. Décalage sur une image
    Par yanniks dans le forum Balisage (X)HTML et validation W3C
    Réponses: 10
    Dernier message: 05/01/2012, 20h40
  3. Opération de décalage sur une image
    Par mmx dans le forum OpenCV
    Réponses: 0
    Dernier message: 16/02/2009, 11h35
  4. Importation d'une image dans la page de titre
    Par Aymenouch dans le forum Tableaux - Graphiques - Images - Flottants
    Réponses: 5
    Dernier message: 14/06/2007, 10h50
  5. Réponses: 1
    Dernier message: 22/11/2006, 17h11

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