Largeurs de colonnes exactement égales dans la grille CSS
Créer des colonnes de taille égale dans la grille CSS peut sembler simple, mais cela nécessite une approche spécifique. Alors que Flexbox offre une solution simple avec sa propriété flex-basis, CSS Grid nécessite une configuration plus précise.
Défi :
Étant donné une structure HTML comme :
<code class="html"><div class="row"> <div class="item"></div> <div class="item"></div> <div class="item"></div> </div></code>
Le but est d'afficher ces éléments dans des colonnes égales, quel que soit le nombre d'éléments enfants dans la ligne.
Solution :
Le commun l'approche de repeat(3, 1fr) est insuffisante, car 1fr distribue l'espace disponible plutôt que d'appliquer une stricte égalité des colonnes. Dans les cas où le contenu dépasse la taille de la piste, il ne s'ajuste pas automatiquement, ce qui peut entraîner des largeurs de colonnes inégales.
Pour obtenir des largeurs de colonnes exactement égales, utilisez la propriété CSS suivante :
<code class="css">grid-template-columns: repeat(3, minmax(0, 1fr));</code>
Explication :
minmax(0, 1fr) permet aux pistes de la grille d'être aussi petites que 0 mais aussi grandes que 1fr. Cela garantit que les colonnes restent égales. Soyez toutefois prudent, car cela peut provoquer des débordements si le contenu est plus grand que la colonne ou s'il ne peut pas être renvoyé à la ligne.
Considérez l'exemple suivant pour illustrer la différence :
<code class="css">.equalColumns { display: grid; grid-template-columns: repeat(3, 1fr); } .minmaxEqualColumns { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); }</code>
equalColumns avec répétition(3, 1fr):
minmaxEqualColumns avec répétition(3, minmax(0, 1fr)):
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!