line-height

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.

La propriété line-height définit la hauteur de la boîte d'une ligne.

Sur les éléments de bloc, la propriété line-height indique la hauteur minimale des lignes au sein de l'élément. Sur les éléments en ligne qui ne sont pas remplacés, line-height indique la hauteur utilisée pour calculer la hauteur de la boîte d'une ligne.

Exemple interactif

line-height: normal;
line-height: 2.5;
line-height: 3em;
line-height: 150%;
line-height: 32px;
Far out in the uncharted backwaters of the unfashionable end of the western spiral arm of the Galaxy lies a small unregarded yellow sun.
#example-element {
  font-family: Georgia, sans-serif;
  max-width: 200px;
}

Syntaxe

css
/* Valeur avec un mot-clé */
line-height: normal;

/* Type  */
/* S'il n'y a pas d'unité, cela
   représente un facteur multiplicateur
   de la taille de la police appliquée à
   l'élément */
line-height: 3.5;

/* Valeur de longueur */
/* Type       */
line-height: 3em;

/* Valeurs proportionnelles */
/* Type         */
line-height: 34%;

/* Valeurs globales */
line-height: inherit;
line-height: initial;
line-height: unset;

La propriété line-height peut être définie grâce :

  • à un nombre (une valeur de type )
  • à une longueur (une valeur de type )
  • à un pourcentage (une valeur de type )
  • au mot-clé normal

Valeurs

normal

Le comportement dépend de l'agent utilisateur. Pour les navigateurs de bureau, l'agent utilisateur prend généralement une valeur environ égale à 1.2 selon la valeur de font-family.

La valeur utilisée est sans unité (type ) et correspond à un facteur multiplicateur de la taille de fonte utilisée. La valeur calculée est la même que celle définie avec . Dans la plupart des cas, c'est la méthode qu'on privilégiera pour définir line-height et éviter les effets de l'héritage.

La valeur de longueur (type ) est utilisée pour calculer la hauteur de la boîte de la ligne. Les différentes unités qui peuvent être utilisées sont décrites avec la page . Les valeurs exprimées en em peuvent produire des résultats inattendus.

La valeur exprimée est relative à la taille de fonte utilisée pour l'élément. La valeur calculée sera le pourcentage (type ) indiqué, multiplié par la taille calculée de la police de l'élément. Voir la section Notes pour plus de précisions sur le comportement de ce type et des valeurs exprimées en em.

-moz-block-height Non standard

La hauteur de la ligne correspond à la hauteur du contenu pour le bloc courant.

Définition formelle

Valeur initialenormal
Applicabilitétous les éléments. S'applique aussi à ::first-letter et ::first-line.
Héritéeoui
Pourcentagesse rapporte à la taille de la police de l'élément lui-même
Valeur calculéepour les valeurs en pourcentages ou en longueur, la longueur absolue, sinon, comme spécifié
Type d'animationeither number or length

Syntaxe formelle

Exemples

css
/* Toutes les règles qui suivent
   fourniront un résultat équivalent */

div {
  line-height: 1.2;
  font-size: 10pt;
} /* number */
div {
  line-height: 1.2em;
  font-size: 10pt;
} /* length */
div {
  line-height: 120%;
  font-size: 10pt;
} /* percentage */
div {
  font:
    10pt/1.2 Georgia,
    "Bitstream Charter",
    serif;
}

Notes

  • Plus souvent, on utilisera la propriété raccourcie font plutôt que line-height. Pour cette propriété raccourcie, il est cependant nécessaire d'avoir une valeur pour la propriété font-family.

Gestion de l'héritage et valeurs sans unité

Dans cet exemple, on voit qu'il est préférable d'utiliser des valeurs de type plutôt que des valeurs de longueur (type .

On utilisera deux éléments

. Le premier aura une bordure verte et une valeur sans unité. Le second aura une bordure rouge et une valeur de longueur

CSS

css
.green {
  line-height: 1.1;
  border: solid limegreen;
}
.red {
  line-height: 1.1em;
  border: solid red;
}
h1 {
  font-size: 30px;
}
.box {
  width: 18em;
  display: inline-block;
  vertical-align: top;
  font-size: 15px;
}

HTML

html

Avoid unexpected results by using unitless line-height

length and percentage line-heights have poor inheritance behavior ...

Avoid unexpected results by using unitless line-height

length and percentage line-heights have poor inheritance behavior ...

Résultat

Accessibilité

Il est nécessaire d'utiliser une valeur minimale de 1.5 pour la propriété line-height lorsqu'on l'applique sur le contenu des paragraphes principaux. Cela aidera les personnes ayant du mal à lire et les personnes dyslexiques. Utiliser une valeur sans unité permet de garantir une mise à l'échelle proportionnelle lorsqu'on zoome/dézoome.

Spécifications

Specification
CSS Inline Layout Module Level 3
# line-height-property

Compatibilité des navigateurs

Voir aussi