vertical-align
Baseline
Large disponibilité
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis juillet 2015.
La propriété raccourcie CSS vertical-align définit l'alignement vertical d'une boîte en ligne (inline en anglais), en ligne et bloc (inline-block en anglais) ou d'une boîte de cellule de tableau.
Propriétés constitutives
Cette propriété est une propriété raccourcie pour les propriétés CSS suivantes :
Exemple interactif
vertical-align: baseline;
vertical-align: top;
vertical-align: middle;
vertical-align: bottom;
vertical-align: sub;
vertical-align: text-top;
<section class="default-example" id="default-example">
<p>
Alignez l'étoile :
<img id="example-element" src="/shared-assets/images/examples/star2.png" />
</p>
</section>
#default-example > p {
line-height: 3em;
font-family: monospace;
font-size: 1.2em;
text-decoration: underline overline;
}
La propriété vertical-align peut être utilisée dans deux contextes :
- Pour aligner verticalement la boîte d'un élément en ligne à l'intérieur de la boîte en ligne de son conteneur. Par exemple, elle peut être utilisée pour positionner verticalement une image dans une ligne de texte.
- Pour aligner verticalement le contenu d'une cellule dans un tableau.
Utilisez cette syntaxe raccourcie (vertical-align) à la place des propriétés correspondantes en forme longue, sauf si vous avez besoin de les appliquer en cascade de manière indépendante ou (sur les éléments SVG) pour assurer la compatibilité avec les anciennes implémentations SVG.
Notez que vertical-align ne s'applique qu'aux éléments en ligne, en ligne-bloc et aux cellules de tableau : vous ne pouvez pas l'utiliser pour aligner verticalement des éléments de niveau bloc.
Syntaxe
/* Valeurs avec un mot-clé */
vertical-align: baseline;
vertical-align: sub;
vertical-align: super;
vertical-align: text-top;
vertical-align: text-bottom;
vertical-align: middle;
vertical-align: top;
vertical-align: bottom;
/* Valeurs de type <length> */
vertical-align: 10em;
vertical-align: 4px;
/* Valeurs de type <percentage> */
vertical-align: 20%;
/* Valeurs globales */
vertical-align: inherit;
vertical-align: initial;
vertical-align: revert;
vertical-align: revert-layer;
vertical-align: unset;
La propriété vertical-align s'utilise avec une des valeurs suivantes.
Valeurs pour les éléments en lignes
Valeurs relatives au parent
Ces valeurs alignent l'élément verticalement, relativement à son élément parent :
baseline-
Aligne la ligne de base de l'élément avec celle de son parent. La ligne de base de certains éléments remplacés, comme
<textarea>, n'est pas définie par la spécification HTML et le comportement de ce mot-clé peut donc changer d'un navigateur à un autre. sub-
Aligne la ligne de base sur la ligne de base inférieure (celle utilisée pour les indices) de l'élément parent.
super-
Aligne la ligne de base sur la ligne de base supérieure (celle utilisée pour les exposants) de l'élément parent.
text-top-
Aligne le haut de l'élément avec le haut de la police de l'élément parent.
text-bottom-
Aligne le bas de l'élément avec le bas de la police de l'élément parent.
middle-
Aligne le milieu de l'élément avec la hauteur donnée par la ligne de base de l'élément parent à laquelle on ajoute la moitié de sa hauteur en x (x-height).
<length>-
Aligne la ligne de base de l'élément à la hauteur de la ligne de base de l'élément parent à laquelle on ajoute la hauteur donnée. Les valeurs négatives sont autorisées.
<percentage>-
Aligne la ligne de base de l'élément à un pourcentage donné au-dessus de la ligne de base de son parent, la valeur étant un pourcentage de la propriété
line-height. Une valeur négative est autorisée.
Valeurs relatives à la ligne
Les valeurs suivantes alignent l'élément par rapport à la ligne entière plutôt que par rapport à leur parent :
top-
Aligne le haut de l'élément et de ses descendants avec le haut de la ligne entière.
bottom-
Aligne le bas de l'élément et de ses descendants avec le bas de la ligne entière.
Pour les éléments qui n'ont pas de ligne de base définie, c'est le bord de la marge basse qui est utilisée.
Valeurs pour les cellules de tableau
baseline(etsub,super,text-top,text-bottom,<length>, et<percentage>)-
La ligne de base de la cellule est alignée avec celle de toutes les autres cellules de la ligne courante qui sont alignées par rapport à la ligne de base.
top-
Aligne le bord haut de la boîte de remplissage (padding en anglais) de la cellule avec le haut de la ligne.
middle-
Centre la boîte de remplissage de la cellule avec la ligne.
bottom-
Aligne le bord bas de la boîte de remplissage avec le bas de la ligne.
Les valeurs négatives sont autorisées.
Définition formelle
| Valeur initiale | baseline |
|---|---|
| Applicabilité | éléments en ligne et à ceux qui sont des cellules de tableau. S'applique aussi à ::first-letter et ::first-line. |
| Héritée | non |
| Pourcentages | se rapporte à la hauteur de ligne de l'élément lui-même |
| Valeur calculée | pour les valeurs exprimées en pourcentages ou en longueur, la longueur absolue, sinon, le mot-clé comme défini |
| Type d'animation | une longueur |
Syntaxe formelle
vertical-align =
[ first | last ] ||
<'alignment-baseline'> ||
<'baseline-shift'>
<alignment-baseline> =
baseline |
<baseline-metric>
<baseline-shift> =
<length-percentage> |
sub |
super |
top |
center |
bottom
<baseline-metric> =
text-bottom |
alphabetic |
ideographic |
middle |
central |
mathematical |
hanging |
text-top
<length-percentage> =
<length> |
<percentage>
Exemples
>Exemple simple
HTML
<div>
Une <img src="frame_image.svg" alt="link" width="32" height="32" />
image avec un alignement par défaut.
</div>
<div>
Une
<img class="haut" src="frame_image.svg" alt="link" width="32" height="32" />
image avec un alignement en haut du texte.
</div>
<div>
Une
<img class="bas" src="frame_image.svg" alt="link" width="32" height="32" />
image avec un alignement en bas du texte.
</div>
<div>
Une
<img class="milieu" src="frame_image.svg" alt="link" width="32" height="32" />
image avec un alignement au milieu.
</div>
CSS
img.haut {
vertical-align: text-top;
}
img.bas {
vertical-align: text-bottom;
}
img.milieu {
vertical-align: middle;
}
Résultat
Alignement vertical sur une boîte de ligne
HTML
<p>
top: <img style="vertical-align: top" src="star.png" alt="étoile"/>
middle: <img style="vertical-align: middle" src="star.png" alt="étoile"/>
bottom: <img style="vertical-align: bottom" src="star.png" alt="étoile"/>
super: <img style="vertical-align: super" src="star.png" alt="étoile"/>
sub: <img style="vertical-align: sub" src="star.png" alt="étoile"/>
</p>
<p>
text-top: <img style="vertical-align: text-top" src="star.png" alt="étoile"/>
text-bottom: <img style="vertical-align: text-bottom" src="star.png" alt="étoile"/>
0.2em: <img style="vertical-align: 0.2em" src="star.png" alt="étoile"/>
-1em: <img style="vertical-align: -1em" src="star.png" alt="étoile"/>
20%: <img style="vertical-align: 20%" src="star.png" alt="étoile"/>
-100%: <img style="vertical-align: -100%" src="star.png" alt="étoile"/>
</p>
Résultat
Alignement vertical d'une cellule de tableau
Dans cet exemple, nous avons un tableau avec une seule ligne contenant six cellules. La ligne définit vertical-align sur bottom comme valeur par défaut.
- Les quatre premières cellules définissent chacune leurs propres valeurs de
vertical-align, qui remplacent la valeur de la ligne. - La cinquième cellule ne définit aucune valeur de
vertical-align, elle hérite donc de la valeur de la ligne.
La sixième cellule est uniquement utilisée pour s'assurer que les cellules sont suffisamment hautes pour voir l'effet.
HTML
<table>
<tbody>
<tr class="bas">
<td class="ligne-de-base">baseline</td>
<td class="haut">top</td>
<td class="milieu">middle</td>
<td>bottom</td>
<td>Style de la ligne</td>
<td>
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Suspendisse
pretium felis eu sem mattis vulputate.
</td>
</tr>
</tbody>
</table>
CSS
table {
margin-left: auto;
margin-right: auto;
width: 80%;
}
table,
th,
td {
border: 1px solid black;
}
td {
padding: 0.5em;
font-family: monospace;
}
.bas {
vertical-align: bottom;
}
.ligne-de-base {
vertical-align: baseline;
}
.haut {
vertical-align: top;
}
.milieu {
vertical-align: middle;
}
Résultat
Spécifications
| Spécification |
|---|
| CSS Inline Layout Module Level 3> # propdef-vertical-align> |