--- title: grid-area slug: Web/CSS/grid-area tags: - CSS - Propriété - Reference translation_of: Web/CSS/grid-area ---
La propriété grid-area
est une propriété raccourcie pour {{cssxref("grid-row-start")}}, {{cssxref("grid-column-start")}}, {{cssxref("grid-row-end")}} et {{cssxref("grid-column-end")}} qui permet de définir la taille d'un objet de la grille et son emplacement via les bords de sa zone de grille.
Le code source de cet exemple interactif est disponible dans un dépôt GitHub. Si vous souhaitez contribuez à ces exemples, n'hésitez pas à cloner https://github.com/mdn/interactive-examples et à envoyer une pull request !
Si quatre valeurs <grid-line>
sont fournies, la première sera appliquée à grid-row-start
, la deuxième à grid-column-start
, la troisième à grid-row-end
et la quatrième à grid-column-end
.
Lorsqu'il n'y a pas de valeur pour grid-column-end
, si grid-column-start
est un identifiant de zone ({{cssxref("<custom-ident>")}}, grid-column-end
sera défini avec cet identifiant, sinon il sera défini avec auto
.
Lorsqu'il n'y a pas de valeur pour grid-row-end
, si grid-row-start
est un identifiant de zone, grid-row-end
sera défini avec cet identifiant, sinon il sera défini avec auto
.
Lorsqu'il n'y a pas de valeur pour grid-column-start
, si grid-row-start
est un identifiant de zone, les quatres propriétés seront définies avec cette valeur. Sinon, elles vaudront auto
.
La propriété grid-area
peut également prendre comme valeur un identifiant personnalisé ({{cssxref("<custom-ident>")}}) qui pourra être utilisé comme nom pour une zone de la grille placée grâce à la propriété {{cssxref("grid-template-areas")}}.
/* Valeurs avec un mot-clé */ grid-area: auto; grid-area: auto / auto; grid-area: auto / auto / auto; grid-area: auto / auto / auto / auto; /* Valeurs de type <custom-ident> */ grid-area: une-zone-de-grille; grid-area: une-zone-de-grille / une-autre-zone; /* Forme : <integer> && <custom-ident>? */ grid-area: une-zone-de-grille 4; grid-area: une-zone-de-grille 4 / 2 une-autre-zone; /* Forme span && [ <integer> || <custom-ident> ] */ grid-area: span 3; grid-area: span 3 / span une-zone-de-grille; grid-area: 2 span / une-autre-zone span; /* Valeurs globales */ grid-area: inherit; grid-area: initial; grid-area: unset;
auto
1
.<custom-ident>
Note : Les noms des zones de grille sont générés implicitement. Ainsi, en utilisant grid-area: foo;
cela sélectionnera le début de la grille nommée correspondante (sauf si une autre ligne foo-start
a été explicitement déclarée).
Sinon, la valeur est traitée comme si on avait utilisé <custom-ident>
et la valeur 1
.
<integer> && <custom-ident>?
Si un nom est fourni pour <custom-ident>, seules les lignes ayant ce nom seront comptées. S'il n'y a pas suffisamment de lignes existant avec ce nom, toutes les lignes implicites seront comptées afin de trouver la position.
Si la valeur entière utilisée est 0
, la règle est invalide.
span && [ <integer> || <custom-ident> ]
Si un nom fourni pour <custom-ident>, seules les lignes ayant ce nom seront comptées. S'il n'y a pas suffisamment de lignes existantes avec ce nom, tout les lignes implicites du côté de la grille explicite et qui correspondent à la direction de la recherche seront comptées afin de placer ce fragment.
Si l'entier n'est pas défini, la valeur par défaut qui sera utilisée sera 1
. Les entiers négatifs ou nuls sont invalides.
{{csssyntax}}
#grid { display: grid; height: 100px; grid-template: repeat(4, 1fr) / 50px 100px; } #item1 { background-color: lime; grid-area: 2 / 2 / auto / span 3; } #item2 { background-color: yellow; } #item3 { background-color: blue; }
<div id="grid"> <div id="item1"></div> <div id="item2"></div> <div id="item3"></div> </div>
{{EmbedLiveSample("Exemples", "100%", "150px")}}
Spécification | État | Commentaires |
---|---|---|
{{SpecName("CSS3 Grid", "#propdef-grid-area", "grid-area")}} | {{Spec2("CSS3 Grid")}} | Définition initiale. |
{{cssinfo}}
{{Compat("css.properties.grid-area")}}