Maison > interface Web > tutoriel CSS > Comment maintenir une largeur d'élément cohérente dans les mises en page Flexbox après l'emballage ?

Comment maintenir une largeur d'élément cohérente dans les mises en page Flexbox après l'emballage ?

Patricia Arquette
Libérer: 2024-11-22 11:36:11
original
937 Les gens l'ont consulté

How to Maintain Consistent Item Width in Flexbox Layouts After Wrapping?

Maintenir une largeur d'élément uniforme après l'emballage de la Flexbox

Dans les mises en page Flexbox, maintenir une largeur d'élément cohérente sur plusieurs lignes peut être difficile. Cependant, cela peut être réalisé grâce à une combinaison de propriétés CSS, comme décrit ci-dessous :

Propriétés CSS

flex-grow

Définit le facteur de croissance d'un élément par rapport à d'autres articles. En définissant ceci sur 1, chaque élément a un potentiel de croissance égal.

flex-basis

Définit la taille initiale d'un élément. Ceci détermine la largeur minimale de l'élément.

max-width

Définit la largeur maximale d'un élément, en s'assurant qu'il ne dépasse pas la taille souhaitée.

Médias CSS Requêtes

Les requêtes multimédias sont utilisées pour ajuster la propriété max-width en fonction de la taille de la fenêtre d'affichage, en maintenant ainsi la cohérence de la largeur des éléments sur plusieurs lignes.

Exemple

ul {
  display: flex;
  flex-wrap: wrap;
}

li {
  max-width: 100px;
  flex: 1 0 0;
}

@media (min-width: 200px) {
  li {
    max-width: 50%;
  }
}

@media (min-width: 300px) {
  li {
    max-width: 33.33333%;
  }
}
Copier après la connexion

Explication

Ce CSS définit la largeur initiale de chaque élément à 100px. Il utilise ensuite des requêtes multimédias pour ajuster la propriété max-width à mesure que la taille de la fenêtre d'affichage change, garantissant ainsi que les éléments conservent la largeur souhaitée même lorsqu'ils passent à une nouvelle ligne.

Solution alternative

Flex -Wrap-Fix Mixin

Une alternative plus élégante consiste à utiliser le flex-wrap-fix mixin :

@mixin flex-wrap-fix($flex-basis, $max-viewport-width: 2000px) {
  flex-grow: 1;
  flex-basis: $flex-basis;
  max-width: 100%;

  $multiplier: 1;
  $current-width: 0px;

  @while $current-width < $max-viewport-width {
    $current-width: $current-width + $flex-basis;
    $multiplier: $multiplier + 1;

    @media(min-width: $flex-basis * $multiplier) {
      max-width: percentage(1/$multiplier);
    }
  }
}
Copier après la connexion

Utilisation

Appliquer le mixin à l'élément flex :

.flex-item {
  @include flex-wrap-fix(100px)
}
Copier après la connexion

Ce mixin obtient le même résultat que les requêtes multimédias CSS mais élimine le besoin pour le code répétitif et facilite la maintenance.

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal