--- title: align-items slug: Web/CSS/align-items tags: - CSS - Propriété - Reference translation_of: Web/CSS/align-items ---
La propriété CSS align-items
définit la valeur de {{cssxref("align-self")}} sur l'ensemble des éléments-fils directs. La propriété align-self
définit elle l'alignement d'un objet au sein de son conteneur. Pour les boîtes flexibles, cette propriété contrôle l'alignement par rapport à l'axe secondaire (cross axis). Au sein d'une grille CSS, elle contrôle l'alignement des éléments sur l'axe de bloc de la zone de grille correspondante.
L'exemple qui suit illustre le fonctionnement des différentes valeurs de align-items
au sein d'une grile.
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 !
À l'heure actuelle, cette propriété est prise en charge pour les dispositions Flexbox et grilles CSS. Pour les boîtes flexibles, cela contrôle l'alignement des objets sur l'axe secondaire et pour les grilles, cela contrôle l'alignement sur l'axe en bloc.
/* Mots-clés de base */ align-items: normal; align-items: stretch; /* Alignement géométrique */ /* align-items ne gère pas les valeurs left et right */ align-items: center; /* Les éléments sont regroupés au centre */ align-items: start; /* Les éléments sont regroupés au début */ align-items: end; /* Les éléments sont regroupés à la fin */ align-items: flex-start; /* Les éléments flexibles sont regroupés au début */ align-items: flex-end; /* Les éléments flexibles sont regroupés à la fin */ align-items: self-start; align-items: self-end; /* Alignement par rapport à la ligne de base */ align-items: first; align-items: first baseline; align-items: last baseline; /* Gestion du dépassement */ align-items: safe center; align-items: unsafe center; /* Valeurs globales */ align-items: inherit; align-items: initial; align-items: unset;
normal
start
pour les éléments remplacés, pour les autres éléments positionnés de façon absolue, il est synonyme de stretch
.stretch
.stretch
.stretch
sauf pour les boîtes ayant des dimensions intrinsèques où il se comporte comme start
.flex-start
flex-end
center
start
end
center
self-start
self-end
baseline
first baseline
last baseline
stretch
safe
start
à la place.unsafe
#container { height:200px; width: 240px; align-items: center; /* Cette valeur peut être modifiée dans l'exemple */ background-color: #8c8c8c; } .flex { display: flex; flex-wrap: wrap; } .grid { display: grid; grid-template-columns: repeat(auto-fill, 50px); } div > div { box-sizing: border-box; border: 2px solid #8c8c8c; width: 50px; display: flex; align-items: center; justify-content: center; } #item1 { background-color: #8cffa0; min-height: 30px; } #item2 { background-color: #a0c8ff; min-height: 50px; } #item3 { background-color: #ffa08c; min-height: 40px; } #item4 { background-color: #ffff8c; min-height: 60px; } #item5 { background-color: #ff8cff; min-height: 70px; } #item6 { background-color: #8cffff; min-height: 50px; font-size: 30px; } select { font-size: 16px; } .row { margin-top: 10px; }
<div id="container" class="flex"> <div id="item1">1</div> <div id="item2">2</div> <div id="item3">3</div> <div id="item4">4</div> <div id="item5">5</div> <div id="item6">6</div> </div> <div class="row"> <label for="display">display: </label> <select id="display"> <option value="flex">flex</option> <option value="grid">grid</option> </select> </div> <div class="row"> <label for="values">align-items: </label> <select id="values"> <option value="normal">normal</option> <option value="flex-start">flex-start</option> <option value="flex-end">flex-end</option> <option value="center" selected>center</option> <option value="baseline">baseline</option> <option value="stretch">stretch</option> <option value="start">start</option> <option value="end">end</option> <option value="self-start">self-start</option> <option value="self-end">self-end</option> <option value="first baseline">first baseline</option> <option value="last baseline">last baseline</option> <option value="safe center">safe center</option> <option value="unsafe center">unsafe center</option> <option value="safe right">safe right</option> <option value="unsafe right">unsafe right</option> <option value="safe end">safe end</option> <option value="unsafe end">unsafe end</option> <option value="safe self-end">safe self-end</option> <option value="unsafe self-end">unsafe self-end</option> <option value="safe flex-end">safe flex-end</option> <option value="unsafe flex-end">unsafe flex-end</option> </select> </div>
var values = document.getElementById('values'); var display = document.getElementById('display'); var container = document.getElementById('container'); values.addEventListener('change', function (evt) { container.style.alignItems = evt.target.value; }); display.addEventListener('change', function (evt) { container.className = evt.target.value; });
{{EmbedLiveSample("Exemples", "260px", "290px")}}
Spécification | État | Commentaires |
---|---|---|
{{SpecName("CSS3 Box Alignment", "#propdef-align-items", "align-items")}} | {{Spec2("CSS3 Box Alignment")}} | |
{{SpecName('CSS3 Flexbox', '#propdef-align-items', 'align-items')}} | {{Spec2('CSS3 Flexbox')}} | Définition initiale. |
{{cssinfo}}
{{Compat("css.properties.align-items.flex_context")}}
{{Compat("css.properties.align-items.grid_context")}}