Background - Propriété CSS

background

Résumé des caractéristiques de la propriété background

Description rapide
Résumé des propriétés de l'arrière-plan.
Statut
Standard
Utilisable sur
HTML
Pourcentages
Reportez-vous aux propriétés individuelles.
Valeur initiale
Voir les propriétés individuelles.
Héritée par défaut
Non.
Voir les propriétés individuelles.
Module W3C
Module CSS - Arrière-plans et bordures
 🡇  
 🡅  
Statut du document: CR (document candidat à la recommandation)

Statut du document: REC (recommandation)

Statut du document: DEPR (Ancienne spécification, déclarée obsolète)

Description de la propriété background.

background est une propriété du langage CSS, qui définit l'ensemble des paramètres des arrière-plans. Ces derniers pouvant être constitués d'une simple couleur, d'une image, d'un dégradé, ou d'une combinaison de plusieurs de ces couches.

background est une propriété résumée, qui regroupe plusieurs propriétés définissant l'arrière-plan. Les valeurs sont séparées par des espaces.

L'ordre des valeurs n'a pas trop d'importance car les valeurs possibles sont différentes d'une propriété à l'autre, sauf en ce qui concerne background-position et background-clip qui doivent être citées dans cet ordre. Un slash introduit la ou les valeurs pour la dimension de l'arrière-plan.


Vous pouvez vous reportez à ces différentes propriétés pour connaître leur syntaxe exacte.

Valeurs pour background.

  • background: url('image.png') bottom left / contain repeat scroll border-box content-box #f04218;

    Cette syntaxe est la plus complète de background. Elle reprend les valeurs de toutes les propriétés qu'elle représente, c'est à dire :

    • L'image d'arrière plan (image.png).
    • La position en XY de cette image (bottom left).
    • Après le slash, la taille de l'image (contain).
    • Le mode de répétition (repeat).
    • Le mode de défilement (scroll).
    • La référence pour le positionnement de l'image (border-box).
    • L'étendue de l'image : couvre-t-elle les marges intérieures, la bordure, etc. (content-box).
    • Enfin la couleur (#f04218). celle-ci ne sera visible que à travers les parties transparentes de l'image, ou si celle-ci n'est pas trouvée.

    Toutes les valeurs, sauf l'image, sont optionnelles : en cas d'omission elles sont fixées à leur valeur initiale.

    Reportez-vous aux propriétés détaillées pour avoir plus de précisions sur ces différentes valeurs.

  • background: linear-gradient(90deg,transparent,blue) #f04218;

    Cette syntaxe définit un dégradé (à la place d'une image) et une couleur. Cette dernière sera visible puisque le dégradé comporte une partie transparente.

    Pour plus de précisions sur les dégradés, reportez-vous aux pages linear-gradient(), conic-gradient() et radial-gradient() ou aux pages sur les dégradés répétitifs.

  • background: url('image1.png') ... , url('image2.png') ... yellow;

    Cette syntaxe définit deux images d'arrière-plan et une couleur. Une virgule séparer les images avec leurs paramètres. Si les images peuvent être multiples, la couleur, elle, sera la dernière citée et sera unique.

    La première image citée est au dessus des autres. Puis viens la deuxième, etc. jusqu'à la couleur qui est derrière toutes les images. Ces images ou dégradés peuvent être simplement superposés, mais ils peuvent aussi être mélangés entre eux. Voir pour cela la propriété background-blend-mode.

  • background: initial; background: inherit; background: revert; background: revertLayer; background: unset;

    Les valeurs communes sont présentées sur ces pages : initial, inherit, revert, revert-layer, unset.

Règles générales sur les arrière-plans.

Un arrière-plan est composé d'une couleur et/ou d'une image. Si les deux sont définies, la couleur et positionnée en dessous de l'image : elle sera visible dans les parties transparentes de l'image, ou si l'image n'est pas trouvée, ou à coté de l'image si celle-ci est plus petite que l'élément et qu'elle n'est pas répétée.
La couleur peut également être mélangée avec l'image (voir background-blend-mode).

Exemple : l'arrière-plan de l'élément ci-dessous est composé d'une couleur (lightBlue) et d'une image (un cercle blanc avec de la transparence autour).

L'image peut être remplacée par un dégradé. Six fonctions permettent de définir un dégradé : conic-gradient(), linear-gradient(), radial-gradient() et leurs variantes en dégradé répétitif.

Arrière-plans multiples.

Principe.

Il est possible de définir plusieurs arrière-plans pour un même élément. Ces arrière-plans se superposent dans l'ordre de leur déclaration, le premier cité au dessus. Les arrière-plans suivants ne sont donc pas visibles, sauf dans les cas suivants :

  • Une ou plusieurs des première images n'ont pas été trouvées.
  • Les premières images comportent des zones transparentes.
  • On a prévu un mélange entre les différents arrière-plan avec la propriété background-blend-mode.

Chacune des propriétés relatives aux arrière-plans peut alors comporter une série de valeurs séparées par des virgules, chacune de ces valeurs correspondant à un des arrière-plans.

La propriété background-color fait cependant exception : une seule couleur de fond peut être définie, avec le dernier arrière-plan. Elle sera commune à tous les arrière-plans.

Voici un exemple de deux arrière-plans construits avec les images ci-dessous. Sur l'image background-2.png toutes les parties non bleues sont transparentes.

background-1
background-1.png
background-2
background-2.png

 

Nombres de valeurs différents.

Comment le navigateur va-t-il procéder si le nombre de valeurs est différent d'une propriété à l'autre ?
Dans notre exemple ci-dessous, background-image comporte trois valeurs, tandis que background-size en comporte quatre, et que background-position n'en comporte que deux.

background-image: url('image1.png'), url('image2.png'), linear-gradient(0,blue,lightblue); background-repeat: repeat, repeat, no-repeat; background-size: contain, cover, cover, contain; background-position: border-box, content-box;

Voici les règles :

  • La propriété qui sert de référence pour dénombrer les arrière-plans est background-image. Dans notre exemple background-image compte 3 valeurs.
  • Si les autres propriétés ont un nombre de valeurs identique, les choses sont simples : on affecte chacune des valeurs à l'arrière-plan correspondant. C'est le cas de background-repeat dans notre exemple.
  • Si des propriétés ont des paramètres en plus, ceux-ci seront ignorés. Dans notre exemple background-size a quatre valeurs. La dernière ne sera affectée à aucun des arrière-plan : elle sera ignorée.
  • Enfin, dans le cas ou des propriétés ont moins de valeurs, comme background-position dans l'exemple, la navigateur affecte les valeurs en bouclant sur celles qui sont disponibles. Ainsi image1 aura la position border-box, image2 la position content-box, et image3 sera positionnée sur border-box (on est revenu sur la première valeur).
    La conséquence est que si une seule valeur est définie pour une des propriétés, elle s'appliquera à tous les arrière-plans.

Remarque : Le fait de définir une couleur et une image ne crée par deux arrière-plans.

Valeurs absentes.

La propriété résumée background définit toutes les valeurs : quand une valeur n'est pas précisée, elle est fixée à sa valeur par défaut. On a donc toujours le même nombre de valeurs pour chacun des paramètres d'arrière-plan.

Dans l'exemple ci-dessous, image2 et image3 seront répétées (la valeur initiale pour background-repeat est repeat).

background: url('image1.png') no-repeat, url('image2.png'), url('image3.png');

Exemples d'utilisation de la propriété background.

Cliquez sur les boutons pour afficher les codes CSS.


Arrière-plan défini d'après une couleur

Arrière-plan défini par une image.
Arrière-plan défini par une image ET une couleur.
Cette dernière sera visible si l'image est introuvable ou si elle comporte des paries transparentes.
Arrière-plan défini par une image,
avec précision sur le positionnement de celle-ci et sur sa répétition.
Arrière-plan défini par un dégradé
Voir la fonction linear-gradient().

Compatibilité des navigateurs avec background.

La gestion des arrière-plans, uniques ou multiples ne posent plus de problème avec les navigateurs actuels.

Colonne 1
Support des arrière-plans multiples.
Colonne 2
Suport de la propriété raccourcie background.
Colonne 3
Support des images SVG utilisées en arrière-plan d'un élément.

Remarques :

(1) Les images SVG apparaissent floues lorsqu'elles sont mises à l'échelle.

1
Arrière-plans
Multiples
2
Porpriété
background
3
SVG
Estimation de la prise en charge globale.
97%
96%
98%

Navigateurs sur ordinateurs :

Navigateurs sur mobiles :

Navigateurs obsolètes ou marginaux :

Internet Explorer

KaiOS Browser

Opéra Mobile

Chrome

Edge

Opéra

Safari

Safari sur IOS

Androïd Brower

Chrome pour Androïd

Firefox pour Androïd

Samsung Internet

Firefox

Baidu Browser

QQ Browser

UC Browser pour Androïd

Opéra mini

Histoire de la propriété background.

La propriété résumée background évolue pour suivre les nouvelles possibilités des arrière-plans introduites par la spécification niveau 3. Principalement les arrière-plans multiples, mais aussi l'ajout de nouvelles caractéristiques des arrière-plans : les dimensions (background-size), l'origine (background-origin, et la découpe éventuelle background-clip.

  • CSS 1 - Spécification concernant les feuilles de styles en cascade - Version 1

    Concernant background. Première définition de la propriété résumée background regroupant les valeurs des propriétés background-color, background-image, background-repeat, background-attachment et background-position.
    WD
    17 Novembre 1995
    Document de travail.
    PR
    12 Novembre 1996
    Proposé à la recommandation.
    REC
    17 Décembre 1996
    Recommandation.
    DEPR
    13 Septembre 2018
    Ancienne spécification, déclarée obsolète.
  • CSS 2.1 - Spécification concernant les feuilles de styles en cascade - Révision 1

    Concernant background. La propriété background accepte la valeur inherit (comme toutes les autres propriétés).
    WD
    04 Novembre 1997
    Document de travail.
    PR
    24 Mars 1998
    Proposé à la recommandation.
    REC
    11 Mai 1998
    Recommandation.
  • Module CSS - Arrière-plans et bordures - Niveau 3

    Concernant background. Possibilité d'arrière-plans multiples.
    La propriété résumée background permet de définir également les nouvelles propriétés relatives aux arrière-plans.
    WD
    02 Août 2002
    Document de travail.
    CR
    17 Décembre 2009
    Candidat à la recommandation.
    PR
    REC

Voir aussi, au sujet des arrière-plans.

La spécification du W3C "module CSS - Arrière-plans et bordures" regroupe tout ce qui concerne les bordures et les arrière-plans. Pour faciliter vos recherches, nous listons ci-dessous les principales propriétés en rapport.

Propriétés :

Background
Résumé des propriétés de l'arrière-plan.
background-attachment
Mode de défilement de l'image d'arrière-plan.
background-clip
Définit l'étendue de l'arrière-plan, en particulier par rapport à la bordure et aux marges intérieures..
background-color
Définit la couleur en arrière-plan.
background-image
Définit l'image ou dégradé d'arrière-plan (plusieurs images ou dégradés peuvent coexister).
background-origin
Définit une référence pour positionner l'image d'arrière-plan.
background-position
Définit comment se positionne l'image d'arrière-plan.
background-position-x
Définit comment se positionne l'image d'arrière-plan dans le sens horizontal.
background-position-y
Définit comment se positionne l'image d'arrière-plan dans le sens vertical.
background-repeat
Définit comment est répétée l'image d'arrière-plan.
background-size
Dimensionnement de l'image d'arrière-plan.
border
Propriété résumée qui définit l'ensemble des paramètres des bordures : épaisseur, style et couleur.
border-bottom-color
Définit la couleur du trait de bordure pour le bas de l'élément.
border-bottom-left-radius
Définit le rayon de l'angle arrondi en bas à gauche.
border-bottom-right-radius
Définit le rayon de l'angle arrondi en bas à droite.
border-bottom-style
Définit le style de trait pour la bordure en dessous de l'élément.
border-bottom-width
Définit l'épaisseur du trait de bordure situé en dessous de l'élément.
border-color
Définit la couleur des bordures pour les 4 cotés de l'élément.
border-image
Résumé des propriétés des bordures réalisées avec des images.
border-image-outset
Définit le débordement de l'image de bordure.
border-image-repeat
Définit comment l'image de bordure est répétée ou dilatée pour couvrir la zone voulue.
border-image-slice
Définit comment l'image de bordure est découpée.
border-image-source
Définit le chemin et le nom de fichier pour l'image utilisée pour construire la bordure.
border-image-width
Définit l'épaisseur de la bordure lorsque cette dernière est réalisée avec une image.
border-left-color
Définit la couleur du trait de bordure à gauche de l'élément.
border-left-style
Définit le type de trait pour la bordure sur la gauche de l'élément.
border-left-width
Définit l'épaisseur du trait de bordure situé à gauche de l'élément.
border-radius
Rayon des angles arrondis.
border-right-color
Définit la couleur du trait de bordure à droite de l'élément.
border-right-style
Définit le type de trait pour la bordure à droite de l'élément.
border-right-width
Définit l'épaisseur du trait de bordure situé à droite de l'élément.
border-style
Définit le type de trait pour les quatre bordures autour de l'élément (solide, double, pointillé...).
border-top-color
Définit la couleur du trait de la bordure au dessus de l'élément.
border-top-left-radius
Définit le rayon de l'angle arrondi en haut à gauche.
border-top-right-radius
Définit le rayon de l'angle arrondi en haut à droite.
border-top-style
Définit le type de trait pour la bordure à gauche de l'élément.
border-top-width
Définit l'épaisseur du trait de bordure au dessus de l'élément.
border-width
Définit l'épaisseur du trait de la bordure situé tout autour de l'élément.
box-shadow
Applique un effet d'ombrage sur les blocs en indiquant tous les paramètres : couleur, décalage de l'ombre, flou, etc.