background-size
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2020.
La propriété CSS background-size
définit la taille des images d'arrière-plan pour l'élément. La taille de l'image peut être contrainte, complètement ou partiellement afin de conserver ses proportions.
Exemple interactif
Note : L'espace qui n'est pas rempli par l'image d'arrière-plan aura la couleur définie par la propriété background-color
. De plus, la couleur d'arrière-plan sera visible si l'image d'arrière-plan est transparente.
Syntaxe
/* Valeurs avec un mot-clé */
background-size: cover;
background-size: contain;
/* Une seule valeur */
/* La valeur désigne la largeur de l'image. */
/* La hauteur vaut 'auto' */
background-size: 50%;
background-size: 3.2em;
background-size: 12px;
background-size: auto;
/* Deux valeurs */
/* Première valeur : la largeur de l'image */
/* Seconde valeur : la hauteur de l'image */
background-size: 50% auto;
background-size: 3em 25%;
background-size: auto 6px;
background-size: auto auto;
/* Valeurs pour plusieurs arrière-plans */
background-size: auto, auto; /* À ne pas confondre avec `auto auto` */
background-size: 50%, 25%, 25%;
background-size: 6px, auto, contain;
/* Valeurs globales */
background-size: inherit;
background-size: initial;
background-size: revert;
background-size: unset;
La propriété background-size
peut être définie de différentes façons :
- Avec l'un des mots-clés
contain
oucover
- Avec une seule valeur qui indique la largeur de l'image (la hauteur vaut alors
auto
par défaut) - Avec deux valeurs dont la première représente la largeur et la seconde la hauteur. Chaque valeur peut être une longueur (type
<length>
) ou un pourcentage (type<percentage>
) ou encoreauto
.
Lorsqu'on souhaite paramétrer la taille de plusieurs images d'arrière-plan, on peut séparer ces valeurs par des virgules (l'ordre utilisé entre les valeurs suit celui de background-image
).
Valeurs
contain
-
Un mot-clé qui redimensionne l'image afin qu'elle soit la plus grande possible et que l'image conserve ses proportions. L'image est contrainte dans le conteneur. Les zones éventuellement vides sont remplies avec la couleur d'arrière-plan (définie grâce à
background-color
). Par défaut, l'image est centrée sauf sibackground-position
a été modifiée. cover
-
Un mot-clé dont le comportement est opposé à celui de
contain
. L'image est redimensionnée pour être aussi grande que possible et pour conserver ses proportions. L'image couvre toute la largeur ou la hauteur du conteneur et les parties qui dépassent sont rognées si les proportions du conteneur sont différentes (il n'y a aucun espace libre sur lequel on verrait la couleur d'arrière-plan). auto
-
Un mot-clé qui redimensionne l'image d'arrière-plan afin que ses proportions soient conservées.
<length>
-
Une valeur de type
<length>
qui redimensionne l'image afin que celle-ci occupe la longueur indiquée dans la dimension concernée. Les valeurs négatives ne sont pas autorisées. <percentage>
-
Une valeur de type
<percentage>
qui redimensionne l'image d'arrière-plan proportionnellement à la taille de la zone dédiée à l'arrière-plan, définie viabackground-origin
. Par défaut, cette zone correspond à la boîte de contenu et de remplissage (padding) mais peut être modifiée pour contenir uniquement la boîte de contenu ou, à l'inverse, les boîtes de contenu, remplissage et marge. Si la propriétébackground-attachment
vautfixed
, la zone de positionnement de l'arrière-plan sera la fenêtre du navigateur (sans les barres de défilement). Les valeurs négatives ne sont pas autorisées.
Dimensions intrinsèques et proportions
Le calcul des valeurs dépend des dimensions intrinsèques de l'image (sa largeur et sa hauteur) et de ses proportions intrinsèques (le rapport entre la largeur et la hauteur). Voici les différents cas de figures possibles :
- Une image matricielle (telle qu'une image JPG) possède toujours des dimensions intrinsèques et des proportions intrinsèques.
- Une image vectorielle (telle qu'une image SVG) ne possède pas nécessairement de dimensions intrinsèques. Si elle possède à la fois une dimension verticale et une dimension horizontale intrinsèques, elle possèdera alors des proportions intrinsèques. Si elle ne possède qu'une ou aucune dimension intrinsèque, elle peut avoir ou ne pas avoir de proportions.
- Un dégradé CSS (cf.
<gradient>
) ne possède ni dimension ni proportion intrinsèque. - Les images d'arrière-plan créées avec la fonction
element()
utiliseront les dimensions et proportions intrinsèques de l'élément générateur.
Note : Pour Gecko, les images d'arrière-plan créées avec la fonction element()
sont actuellement traitées comme des images ayant les dimensions de l'élément ou, si la zone de positionnement est un élément SVG, avec les proportions intrinsèques. Ce comportement n'est pas standard.
Selon le caractère intrinsèque ou non des dimensions et des proportions, la taille d'affichage de l'image d'arrière-plan est calculée de la façon suivante :
-
Si les deux composants de
background-size
sont définis et qu'aucun ne vautauto
: L'image utilise la taille définie. -
Si
background-size
vautcontain
oucover
: L'image est affichée et ses proportions sont conservées pour que l'image soit contenue dans la zone ou la recouvre complètement. Si l'image ne possède pas de proportions intrinsèques ; elle est affichée avec la taille de la zone de positionnement de l'arrière-plan. -
Si
background-size
vautauto
ouauto auto
:-
Si l'image possède deux dimensions intrinsèques, c'est cette taille qui est utilisée.
-
Si elle ne possède pas de dimension intrinsèque ni de proportion intrinsèque, elle est affichée avec la taille de la zone dédiée à l'arrière-plan.
-
Si elle n'a aucune dimension mais possède une proportion, elle sera affichée comme si la valeur
contain
avait été utilisée. -
Si l'image possède une dimension intrinsèque et une proportion, elle est affichée avec cette dimension et cette proportion.
-
Si l'image possède une dimension intrinsèque mais aucune proportion, elle sera affichée avec la dimension intrinsèque et l'autre dimension suivra la taille de la zone pour l'arrière-plan.
Note : Les images SVG peuvent contenir un attribut
preserveAspectRatio
pour lequel la valeur par défaut est équivalente àcontain
. Une valeur explicite pourbackground-size
permet d'ignorerpreserveAspectRatio
. -
-
Si
background-size
possède une composanteauto
et que l'autre composante est différente deauto
:- Si l'image possède une proportion intrinsèque, elle sera affichée avec la dimension indiquée et la deuxième sera calculée grâce à la proportion.
- Si l'image ne possède aucune proportion intrinsèque, la dimension indiquée sera utilisée pour la dimension concernée et on utilisera la dimension intrinsèque de l'image pour l'autre axe si elle existe. Sinon, on prendra la dimension de la zone de l'arrière-plan pour cet axe.
Note : Le dimensionnement des images d'arrière-plan qui sont des images vectorielles sans dimension ou proportion intrinsèque n'est pas implémenté par l'ensemble des navigateurs. Attention à bien vérifier le résultat obtenu dans les différents navigateurs par rapport aux règles émises ci-avant.
Utiliser les dégradés
Si vous utilisez un dégradé (<gradient>
) comme arrière-plan et indiquez la propriété background-size
correspondante, il vaut mieux ne pas utiliser une taille qui utilise un seul composant auto
ou qui est définie avec une seule valeur de largeur (par exemple, background-size: 50%
).
L'affichage des dégradés peut différer entre les navigateurs dont certains n'implémentent pas le rendu conformément à la spécification CSS de background-size
et à la spécification pour les dégradés.
.exemple-degrade {
width: 50px;
height: 100px;
background-image: linear-gradient(blue, red);
/* Utilisation risquée */
background-size: 25px;
background-size: 50%;
background-size: auto 50px;
background-size: auto 50%;
/* Peut être utilisé sans problème */
background-size: 25px 50px;
background-size: 50% 50%;
}
Définition formelle
Valeur initiale | auto auto |
---|---|
Applicabilité | tous les éléments. S'applique aussi à ::first-letter et ::first-line . |
Héritée | non |
Pourcentages | relatifs à la zone de positionnement du fond |
Valeur calculée | comme spécifié, mais avec les longueurs relatives converties en longueurs absolues |
Type d'animation | une liste répétable |
Syntaxe formelle
Exemples
Réaliser un pavage
Prenons une image d'une taille qui ne correspond pas forcément à notre document cible. Ici, on a une image de 189x189 pixels et on souhaite réaliser un pavage avec quatre exemplaires de l'image dans un élément qui mesure 300x300 pixels. Pour cela, on fixe la valeur de background-size
à 150 pixels.
HTML
<div class="tiledBackground"></div>
CSS
.tiledBackground {
background-image: url(logo-quantum.png);
background-size: 150px;
width: 300px;
height: 300px;
border: 2px solid;
color: pink;
}
Résultat
Voir Redimensionner des images d'arrière-plan pour plus d'exemples.
Spécifications
Specification |
---|
CSS Backgrounds and Borders Module Level 3 # the-background-size |
Compatibilité des navigateurs
BCD tables only load in the browser