Certaines questions sont examinées ici, mais elles ne résolvent pas tout à fait le problème que je recherche.
Supposons que j'ai un site Web et que je le veuille. Sur le bureau, je veux ceci :
C'est facile. grid-template-columns: 重复(3, 33%)
(En gros)
Mais sur mobile, je veux ça
Ce que j'ai rencontré s'est produit avant qu'il ne reste une seule colonne :
J'essaie clamp()
、minmax()
et toutes sortes de choses, mais rien ne fonctionne comme je le souhaite. Oui, je pourrais certainement utiliser des requêtes multimédias, mais j'aimerais créer une mise en page grille/flex vraiment fluide en utilisant du CSS moderne (comme clamp, grid, minmax, etc.) afin qu'aucune requête multimédia ne soit nécessaire pour apporter des modifications de mise en page de base. < /p>
Je sais que cela ne fonctionne pas, mais comme point de départ pour les requêtes, voici une version simple d'une de mes 100 tentatives :) Dans cette version, j'essaie de passer de répétition(3) à répétition(1) en utilisant clamp) .
.wrapper { display: grid; gap: 15px; grid-template-columns: repeat(clamp(1, calc(100% - 500px), 3), 33%); } .one { background: red; } .two { background: green; } .three { background: blue; }
<div class="wrapper"> <div class="item one"><h3>Example A</h3></div> <div class="item two"><h3>Example Two</h3></div> <div class="item three"><h3>Third Example</h3></div> </div>
Article complet avec des règles plus générales : https://css-tricks.com/responsive-layouts-fewer-media-queries/
Ceci est utilisé en base flexible
max(0px, (400px - 100vw)*1000)
的想法。如果100vw
(屏幕尺寸)大于400px
,则此公式将给出0px
,或者在相反情况下给出一个非常大的值,为每个元素提供一个bigflex-basis
并创建一个包装。只需调整400px
即可扮演@media (max-width:400px)
En utilisant CSS Grid, cela peut ressembler à ceci :
Une question similaire où je contrôle le nombre maximum de colonnes sans requêtes multimédias : Grille CSS - Nombre maximum de colonnes sans requêtes multimédias
Nous pouvons étendre la solution ci-dessus pour considérer des cas plus complexes.
Exemple de passage de 6 colonnes à 3 colonnes à 1 colonne :
Pour comprendre ces valeurs, considérez les plages suivantes :
Pour obtenir 6 colonnes dont nous avons besoin
]14.3% 16.7%]
范围内的值(我考虑的是15%
) Pour obtenir 3 colonnes dont nous avons besoin]25% 33.3%]
范围内的值(我考虑的是30%
)Nous évitons simplement les bords pour nous assurer de tenir compte des espaces.
Une solution plus générale utilisant des variables CSS, où j'ajouterais
0.1%
pour m'assurer que la valeur est suffisamment grande pour obtenir le nombre de colonnes souhaité et peut combler les lacunes.Nous ajoutons également une coloration dynamique (en relation : Comment changer la couleur d'un élément en fonction de sa hauteur ou de sa largeur ? )
Avec flexbox, nous pouvons avoir un comportement différent (éventuellement souhaité) où le dernier élément d'une ligne occupera tout l'espace disponible :