grid-row
Baseline
Widely available
Cette fonctionnalité est bien établie et fonctionne sur de nombreux appareils et versions de navigateurs. Elle est disponible sur tous les navigateurs depuis octobre 2017.
La propriété raccourcie CSS grid-row définit la taille et l'emplacement d'un élément de la grille dans une ligne de grille en ajoutant une ligne, un fragment (span en anglais) ou rien (automatique) à son placement sur la grille, définissant ainsi les bords de début et de fin en ligne de sa zone de grille.
Exemple interactif
grid-row: 1;
grid-row: 1 / 3;
grid-row: 2 / -1;
grid-row: 1 / span 2;
<section class="default-example" id="default-example">
<div class="example-container">
<div class="transition-all" id="example-element">Un</div>
<div>Deux</div>
<div>Trois</div>
</div>
</section>
.example-container {
border: 1px solid #c5c5c5;
display: grid;
grid-template-columns: 1fr 1.5fr 1fr;
grid-template-rows: repeat(3, minmax(40px, auto));
grid-gap: 10px;
width: 200px;
}
.example-container > div {
background-color: rgb(0 0 255 / 0.2);
border: 3px solid blue;
}
#example-element {
background-color: rgb(255 0 200 / 0.2);
border: 3px solid rebeccapurple;
}
Propriétés constitutives
Cette propriété est une propriété raccourcie pour les propriétés CSS suivantes :
Syntaxe
/* Valeurs avec un mot-clé */
grid-row: auto;
grid-row: auto / auto;
/* Valeurs de type <custom-ident> */
grid-row: une-zone-de-grille;
grid-row: une-zone-de-grille / une-zone-de-grille;
/* Valeurs de type <integer> + <custom-ident> */
grid-row: une-zone-de-grille 4;
grid-row: 4 une-zone-de-grille / 6;
/* Valeurs span + <integer> + <custom-ident> */
grid-row: span 3;
grid-row: span une-zone-de-grille;
grid-row: 5 une-zone-de-grille span;
grid-row: span 3 / 6;
grid-row: span une-zone-de-grille / span une-zone-de-grille;
grid-row: 5 une-zone-de-grille span / 2 span;
/* Valeurs globales */
grid-row: inherit;
grid-row: initial;
grid-row: revert;
grid-row: revert-layer;
grid-row: unset;
Cette propriété se définit avec une ou deux valeurs <grid-line>.
Si deux valeurs <grid-line> sont données, elles sont séparées par une barre oblique (/). La propriété longue grid-row-start prend la valeur avant la barre oblique, et la propriété longue grid-row-end prend la valeur après la barre oblique.
Chaque valeur <grid-line> peut être définie comme :
- soit le mot-clé
auto. - soit une valeur
<custom-ident>. - soit une valeur
<integer>. - soit les deux,
<custom-ident>et<integer>, séparés par un espace. - soit le mot-clé
spanavec soit une valeur<custom-ident>, soit une valeur<integer>, soit les deux.
Valeurs
auto-
Un mot-clé qui indique que la propriété ne contribue pas au placement de l'élément sur la grille. Cela indique un placement automatique, une taille de fragment (span en anglais) automatique ou une taille par défaut de
1. <custom-ident>-
S'il existe une ligne nommée avec
<custom-ident>-start/<custom-ident>-end, la première ligne correspondante contribue au placement de l'élément sur la grille.Note : Les noms des zones de grille sont générés implicitement. Ainsi, en utilisant
grid-row: toto;cela sélectionnera le début de la grille nommée correspondante (sauf si une autre lignetoto-start/toto-enda été explicitement déclarée).Sinon, la valeur est traitée comme si on avait utilisé
<custom-ident>et la valeur1. <integer> && <custom-ident>?-
La n-ième ligne de la grille contribue au placement de l'élément sur la grille. Si un entier négatif est utilisé, le comptage sera fait depuis la fin de la grille explicite.
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 (
<integer>) utilisée est0, la règle est invalide. span && [ <integer> || <custom-ident> ]-
Un fragment de grille est utilisé pour le placement de l'élément sur la grille afin que le début de la ligne pour l'élément de la grille soit placé à n lignes du bord de fin.
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 (
<integer>) n'est pas défini, la valeur par défaut qui sera utilisée sera1. Les entiers négatifs ou nuls sont invalides.
Définition formelle
| Valeur initiale | pour chaque propriété individuelle de la propriété raccourcie :
|
|---|---|
| Applicabilité | éléments de grilles et boîtes positionnées de façon absolue dont le bloc englobant est un conteneur de grille |
| Héritée | non |
| Valeur calculée | pour chaque propriété individuelle de la propriété raccourcie :
|
| Type d'animation | discrète |
Syntaxe formelle
grid-row =
<grid-line> [ / <grid-line> ]?
<grid-line> =
auto |
<custom-ident> |
[ [ <integer [-∞,-1]> | <integer [1,∞]> ] && <custom-ident>? ] |
[ span && [ <integer [1,∞]> || <custom-ident> ] ]
<integer> =
<number-token>
Exemples
>Définir la taille et l'emplacement d'une ligne de grille
HTML
<div id="grid">
<div id="item1"></div>
<div id="item2"></div>
<div id="item3"></div>
</div>
CSS
#grid {
display: grid;
height: 200px;
grid-template-columns: 200px;
grid-template-rows: repeat(6, 1fr);
}
#item1 {
background-color: lime;
}
#item2 {
background-color: yellow;
grid-row: 2 / 4;
}
#item3 {
background-color: blue;
grid-row: span 2 / 7;
}
Résultat
Spécifications
| Specification |
|---|
| CSS Grid Layout Module Level 2> # placement-shorthands> |
Compatibilité des navigateurs
Voir aussi
- La propriété
grid-row-start - La propriété
grid-row-end - La propriété raccourcie
grid-column - La propriété
grid-column-start - La propriété
grid-column-end - Placer les éléments d'une grille sur les lignes
- Vidéo : le placement des éléments d'une grille sur les lignes (angl.)