Background-position - Propriété CSS

background-position
background-position-x
background-position-y

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

Description rapide
Définit comment se positionne l'image d'arrière-plan.
Statut
Standard
S'applique à
Tous les éléments.
Utilisable sur
HTML
Valeurs prédéfinies
bottom | center | left | right | top
Pourcentages
Calculés par rapport à la taille de l'élément moins la taille de l'image de fond.
Valeur initiale
0
Héritée par défaut
Non.
Type d'animation
Repeatable list : liste répétable.
Module W3C
Module CSS - Arrière-plans et bordures
Références (W3C)
 🡇  
 🡅  
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)

Schéma de la syntaxe de background-position.

background-position - Syntax DiagramSyntax diagram of the background-position CSS property. left left right right center center length / % length / % , , length/% length/% top top bottom bottom center center length / % length / % length/% length/%background-position:;background-position:;
Schéma syntaxique de la propriété background-position
Cliquez sur les liens du schéma pour plus de détails sur les valeurs
Télécharger le schéma en SVG

Sur le schéma, les termes en gras sont les mots prédéfinis de CSS, les autres termes sont décrits ci-dessous :

  • length sont des valeurs numériques suivies d'une des unités de dimension.
  • % sont des pourcentages qui se résolvent en une dimension.
  • Le premier groupe de valeur concerne le positionnement horizontal, le deuxième groupe le positionnement vertical.
  • Toute la syntaxe peut être répétée autant de fois qu'il y a d'arrière-plans définis, chaque occurrence étant séparée par une virgule.

Description de la propriété background-position.

background-position définit comment se positionne l'arrière-plan par rapport à l'élément. Si l'arrière-plan est répété sur toute la surface, la propriété background-position provoque simplement un décalage du motif. C'est une propriété résumée pour remplacer les propriétés :

  • background-position-x : positionnement horizontal de l'arrière-plan.
  • background-position-y : positionnement vertical de l'arrière-plan.

Deux valeurs peuvent donc être utilisées avec background-position, la première pour le positionnement horizontal et la deuxième pour le positionnement vertical. Lorsqu'une seule des deux valeurs est indiquée, l'autre est assimilée à center.

Par défaut (si background-position n'est pas utilisée) l'arrière-plan est positionné en haut et à gauche de l'élément.

Reportez-vous à la page background pour des explications générales sur les arrière-plans. Et plus bas sur cette page pour des informations sur le positionnement précis de l'arrière-plan.

Valeurs pour background-position.

  • background-position: left; background-position: center; background-position: right;

    Ces trois valeurs définissent le positionnement horizontal de l'arrière-plan. Sans indication supplémentaire, le positionnement vertical sera alors fixé à center.

  • background-position: top; background-position: center; background-position: bottom;

    Ces trois valeurs définissent le positionnement vertical de l'arrière-plan. Sans indication supplémentaire, le positionnement horizontal sera fixé à center.

  • background-position: right top;

    Pour préciser le positionnement de l'arrière-plan dans les deux directions, il faut préciser deux valeurs, séparées par un espace.

  • background-position: right 10px bottom 20px;

    Les valeurs vues précédemment peuvent être suivies d'un nombre positif ou négatif, avec une unité de dimension. Voir les unités de dimension.
    Les valeurs positives déplacent l'arrière-plan vers le centre de l'élément, tandis que les valeurs négatives le déplacent vers l'extérieur. Voyez les explications plus bas sur cette page au sujet du positionnement précis de l'arrière-plan.

  • background-position: 10px 30px;

    Deux valeurs numériques, positives ou négatives, avec une unité de dimension. Elles définissent respectivement le positionnement horizontal et vertical de l'arrière-plan.

    Cette syntaxe est équivalente à left 10px top 30px;

  • background-position: right top, center top;

    La virgule est utilisée pour séparer les informations concernant des arrière-plans différents. Reportez-vous à background pour des explications plus complètes sur les arrière-plans multiples.

Valeurs globales
(communes à toutes les propriétés)

background-position: initial (0) background-position: inherit background-position: revert background-position: revertLayer background-position: unset

Consultez les pages suivantes pour plus de détails : initial, inherit, revert, revert-layer, unset.

Pour entrer dans le détail.

Pour être précis, background-position positionne l'arrière-plan par rapport à un point de référence, lui-même défini par la propriété background-origin. Par défaut ce point de référence se situe dans le coin en haut à gauche de l'élément.

Les valeurs left top positionnent l'arrière-plan sur ce point de référence, tandis que les valeurs right bottom le positionnent sur le point symétrique, situé en bas à droite de l'élément.

Par défaut, les marges intérieures (padding) sont incluses entre ces deux points de référence mais la propriété background-origin peut changer ça.

Propriété background-position

La syntaxe suivante va donc positionner le coté gauche de l'image d'arrière-plan 10 pixels à droite du premier point de référence, et le bas de l'image à 20 pixels au-dessus du deuxième point de référence.

background-position: top 10px bottom 20px;

Les choses se compliquent si ces dimensions sont indiquées en pourcentages. Il faut d'abord définir ce qu'est la zone de référence : c'est la zone comprise entre les deux points de référence.

Background-position

Le pourcentage horizontal est calculé par rapport à (largeur de la zone de référence - largeur de l'image d'arrière-plan).

Le pourcentage vertical est calculé par rapport à (hauteur de la zone de référence - hauteur de l'image d'arrière-plan).

Cette complication a des avantages : 50% correspond à une image d'arrière-plan centrée sur l'élément, ce qui est assez intuitif. D'autre part left 100% est équivalent à right.

Exemple d'animation de background-position.

Les propriétés relaties au positionnement de l'arrière-plan peuvent être animées facilement. L'exemple ci-dessous est une animation suivant l'axe horizontal (propriété background-position-x. L'impression d'un défilement continu est due au fait que la largeur de l'élément (300 pixels) est un multiple entier de la largeur de l'image (150 pixels). L'effet est renforcé par une fonction d'accélération linéaire (animation-timing-function:linear).

Accéder à la propriété background-position par programme.

Modifier la valeur de background-position en Javascript.

Voici comment modifier la valeur de background-position. Javascript accepte deux syntaxes :

  • Avec la notation typique de CSS, en kebab-case (un tiret pour séparer les mots).
  • Et avec la notation en camel-case, plus courante en Javascript (une majuscule pour séparer les mots).
Javascript
let el = document.getElementById('id'); let value = el.style['background-position']; // ou let el = document.getElementById('id'); let value = el.style.backgroundPosition;

Lire en Javascript la valeur de background-position.

Ce code lit la valeur de background-position affectée dans le code HTML, via l'attribut style (ou via un code Javascript comme celui ci-dessus).

Javascript
let el = document.getElementById('id'); let value = el.style['background-position']; // ou let el = document.getElementById('id'); let value = el.style.backgroundPosition;

Lire la valeur calculée de background-position en Javascript.

La valeur calculée est celle qui résulte de la cascade d'héritages : valeur sur l'élément lui-même, valeur héritée, valeur initiale. La valeur est renvoyée sous la forme de deux pourcentages, même si la propriété a été assignée avec un terme prédéfini comme center par exemple.

Javascript
let el = document.getElementById('id'); let value = window.getComputedStyle(el).getPropertyValue('background-position');

Modifier la valeur de la propriété background-position avec JQuery.

JQuery

$('#id').css('background-position', 'center top');
// ou
$('#id').css('backgroundPosition', 'center top');

Lire la valeur calculée de la propriété background-position avec JQuery.

La valeur est renvoyée sous la forme de deux pourcentages ou de deux dimensions en pixels, le premier pour le positionnement horizontal, et le deuxième pour le positionnement vertical.

JQuery
let value = $('#id').css('background-position');

Autres codes.

La page Javascript et CSS vous fournit d'autres exemples de code Javascript et JQuery.

Testez vous-même.

Les boutons ci-dessous appliquent la valeur saisie à la propriété background-position et affichent ensuite soit la valeur telle qu'elle a été appliquée, soit la valeur calculée. Cette deuxième option permet de voir comment est mémorisée (sérialisée) la valeur de background-position. On constate en particulier que les valeurs prédéfinies sont mémorisées sous la forme de pourcentage, et que toutes les unités de dimension sont ramenées en pixels.

Exemple interactif avec la propriété background-position.

Ce simulateur est intéressant pour comprendre la logique de calcul des pourcentages. L'image mesure 150x150 pixels et, sur un écran de PC, l'élément mesure environ 750 pixels de large.
Si on demande un positionnement horizontal à 30%, le calcul est le suivant :
30% x (750 - 150) = 180 pixels, soit environ 24% de la largeur de l'élément.
Faites l'essai : vous verrez que le bord gauche de l'image est bien à peu près à 24% sur la graduation. Mais quoiqu'il en soit 50% place l'image au milieu de l'élément.

background-position-x :
background-position-y :
Image d'arrière-plan non répétée
Image d'arrière-plan répétée

Compatibilité des navigateurs avec background-position.

Aucun problème de compatibilité n'est à signaler : tous les navigateurs prennent correctement en charge la propriété background-position.

Colonne 1
Support de la propriété background-position pour positionner l'arrière-plan.
Colonne 2
Traitement correct de la syntaxe de background-position permettant de positionner l'arrière-plan par rapport à un ou deux des côtés de l'élément.
Exemple : background-position:right 10px bottom 20px;.
1
Porpriété
background-position
2
Position par rapport
aux bordures
Estimation de la prise en charge globale.
96%
97%

Navigateurs sur ordinateurs :

Navigateurs sur mobiles :

Navigateurs obsolètes ou marginaux :

Internet Explorer

Baidu Browser

QQ Browser

Opéra Mobile

Firefox

Chrome

Safari

Edge

Opéra

Chrome pour Androïd

Safari sur IOS

Samsung Internet

UC Browser pour Androïd

Androïd Brower

Firefox pour Androïd

KaiOS Browser

Opéra mini

Histoire de la propriété background-position.

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

Tout ce qui concerne les arrière-plans et les bordures et décrit dans la spécification du W3C "CSS Backgrounds and Borders Module". Voici les principales propriétés décrites dans cette norme.

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-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.
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-color
Définit la couleur des bordures.
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 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-radius
Rayon des angles arrondis.
border-style
Type de bordure (solide, double, pointillé...).
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-width
Définit l'épaisseur de la bordure 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.