Maison interface Web tutoriel CSS Comment puis-je réaliser des transitions de mise en page fluides sans utiliser de requêtes multimédias ?

Comment puis-je réaliser des transitions de mise en page fluides sans utiliser de requêtes multimédias ?

Nov 17, 2024 am 03:37 AM

How Can I Achieve Fluid Layout Transitions Without Using Media Queries?

Transitions de mise en page fluides sans requêtes multimédias : un guide complet

Lors de la conception d'un site Web, réaliser une transition transparente entre les mises en page de bureau et mobiles sans recourir répondre aux requêtes des médias peut être une tâche difficile. Ce guide abordera une technique qui exploite les CSS modernes, en particulier clamp(), grid, minmax() et flexbox, pour obtenir une mise en page fluide qui s'adapte gracieusement à différentes tailles d'écran.

Considérez un site Web avec un disposition à trois colonnes sur ordinateur et disposition à une seule colonne sur mobile. Pour réaliser cette transition, nous nous concentrerons sur une disposition de grille spécifique basée sur des colonnes répétées. Sur le bureau, nous pouvons facilement créer une mise en page à trois colonnes à l'aide de grid-template-columns : répéter (3, 33 %). Cependant, à mesure que nous passons à des tailles d'écran plus petites, nous rencontrons un problème où la mise en page passe à deux colonnes avant de se réduire à une seule colonne.

Bien que les requêtes multimédias offrent une solution simple, nous recherchons une approche qui repose uniquement sur propriétés CSS modernes. Pour y parvenir, nous utilisons la fonction clamp() en combinaison avec les colonnes de modèle de grille : répéter(clamp(1, calc(100% - 500px), 3), 33%). La fonction clamp() nous permet de définir une valeur minimale, une valeur préférée et une valeur maximale. Dans ce cas, nous définissons la valeur minimale sur 1 colonne, la valeur préférée pour répéter (3) colonnes et la valeur maximale sur 100 % - 500 px.

À mesure que la taille de l'écran diminue, le calcul (100 % - 500px) s'approchera de 0, ce qui amènera la fonction clamp() à afficher une valeur proche de 1. Ceci, à son tour, réduit le nombre de colonnes à 1, rendant ainsi la mise en page à une seule colonne.

Une autre solution viable consiste à utiliser flexbox et max(0px, (400px - 100vw)*1000) dans la propriété flex-basis. Cette formule nous permet de définir une base flexible qui sera de 0 px lorsque la fenêtre d'affichage est plus large que 400 px (en supposant que 400 px soit le point d'arrêt souhaité). Pour les largeurs de fenêtre inférieures à 400 px, la base flexible prendra une valeur élevée, enveloppant efficacement les éléments dans une disposition à une seule colonne.

En tirant parti de ces techniques, nous pouvons créer des mises en page fluides qui transitionnent de manière transparente entre plusieurs colonnes et une seule colonne, offrant une expérience utilisateur réactive sans avoir besoin de requêtes multimédias.

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!

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

Article chaud

Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Ajout d'ombres de boîte aux blocs et éléments WordPress Ajout d'ombres de boîte aux blocs et éléments WordPress Mar 09, 2025 pm 12:53 PM

Ajout d'ombres de boîte aux blocs et éléments WordPress

Créez un formulaire de contact JavaScript avec le cadre Smart Forms Créez un formulaire de contact JavaScript avec le cadre Smart Forms Mar 07, 2025 am 11:33 AM

Créez un formulaire de contact JavaScript avec le cadre Smart Forms

Créer un éditeur de texte en ligne avec l'attribut satisfaistable Créer un éditeur de texte en ligne avec l'attribut satisfaistable Mar 02, 2025 am 09:03 AM

Créer un éditeur de texte en ligne avec l'attribut satisfaistable

Travailler avec GraphQL Caching Travailler avec GraphQL Caching Mar 19, 2025 am 09:36 AM

Travailler avec GraphQL Caching

Faire votre première transition Svelte personnalisée Faire votre première transition Svelte personnalisée Mar 15, 2025 am 11:08 AM

Faire votre première transition Svelte personnalisée

Téléchargement de fichiers avec Multer dans Node.js et Express Téléchargement de fichiers avec Multer dans Node.js et Express Mar 02, 2025 am 09:15 AM

Téléchargement de fichiers avec Multer dans Node.js et Express

Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres) Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres) Mar 04, 2025 am 10:22 AM

Comparaison des 5 meilleurs constructeurs de formulaires PHP (et 3 scripts libres)

Show, ne dit pas Show, ne dit pas Mar 16, 2025 am 11:49 AM

Show, ne dit pas

See all articles