


Regrouper les éléments de la liste de sélection avec la grille CSS
Mar 07, 2025 pm 04:36 PM
GRASSER IMMISSIEMENT LES éléments de liste sélectionnés via la grille CSS pour améliorer l'expérience utilisateur! Le regroupement d'éléments sélectionné est une stratégie de conception courante qui aide les utilisateurs à distinguer rapidement les éléments sélectionnés et non sélectionnés. Par exemple, dans la liste des taches, les éléments terminés montent vers le haut, ce qui facilite la concentration sur les taches restantes.
Nous concevons une interface utilisateur de regroupement similaire. Contrairement au réarrangement simple des éléments sélectionnés, nous utiliserons la grille CSS pour disposer horizontalement les éléments sélectionnés pour distinguer davantage les éléments sélectionnés et non sélectionnés.
Nous explorerons deux méthodes. On utilise auto-fill
, qui convient aux situations où l'élément sélectionné ne dépasse pas la limite du conteneur de la grille, assurant une disposition stable; span
Le code
-
<li>
<li>
). Nous n'avons pas besoin d'envelopper les éléments supplémentaires, car l'attribut GRID CSS déterminera la disposition du projet. Notez que j'utilise des éléments implicites <ul></ul>
pour envelopper, en évitant un emballage supplémentaire, mais les balises explicites sont généralement plus prises en charge par les technologies d'assistance. <label></label>
Méthode 1: Utilisez auto-fill
ul { width: 250px; display: grid; gap: 14px 10px; grid-template-columns: repeat(auto-fill, 40px); justify-content: center; /* ...其他樣式... */ }L'élément
contenant l'élément de liste est défini sur <ul></ul>
pour en faire un conteneur de grille. Il définit un espace de 14px et 10px entre les lignes de grille et les colonnes. Le contenu de la grille est aligné horizontalement sur le centre. La propriété display: grid
spécifie la taille des colonnes dans la grille. Dans l'état initial, tous les éléments se trouvent dans une seule colonne. Une fois les éléments sélectionnés, ils passeront à la première ligne, chaque élément sélectionné occupant une colonne. La clé réside dans la valeur. grid-template-columns
La valeur auto-fill
. Il garantit que les colonnes sont répétées, chaque colonne a la taille de piste donnée dans auto-fill
(40px dans l'exemple) et peut s'adapter aux limites du récipient de grille. repeat()
repeat()
pour s'assurer que l'état initial de l'élément de liste est une seule colonne:
Lorsque l'élément est sélectionné (l'élément
li { width: inherit; grid-column: 1; /* 等同于:grid-column-start: 1; grid-column-end: auto; */ /* ...其他樣式... */ }est sélectionné), utilisez le sélecteur
: <input>
:has(:checked)
li { width: inherit; grid-column: 1; /* ...其他樣式... */ &:has(:checked) { grid-area: 1; /* 等同于:grid-row-start: 1; grid-column-start: auto; grid-row-end: auto; grid-column-end: auto; */ width: 40px; /* ...其他樣式... */ } /* ...其他樣式... */ }
Méthode 2: Utilisez le mot-clé
span
Cette méthode ne nécessite pas l'attribut
est le suivant: grid-template-columns
<ul></ul>
ul { width: 250px; display: grid; gap: 14px 10px; justify-content: center; justify-items: center; /* ...其他樣式... */ }Aide à aligner les éléments de la grille. Style
mis à jour: justify-items: center
<li>
li { width: inherit; grid-column: 1 / span 6; /* 等同于:grid-column-start: 1; grid-column-end: span 6; */ /* ...其他樣式... */ }La déclaration gardera les articles centrés.
justify-items: center
li { width: inherit; grid-column: 1 / span 6; /* ...其他樣式... */ &:has(:checked) { grid-area: 1; width: 120px; /* ...其他樣式... */ } /* ...其他樣式... */ }
Sélectionner l'ordre
L'ordre des éléments sélectionnés et non sélectionnés restera le même que l'ordre source. Si l'ordre d'écran est nécessaire pour correspondre à la sélection de l'utilisateur, la valeur de commande incrémentée est attribuée dynamiquement lorsque l'élément est sélectionné. Résumé La grille CSS rend les deux méthodes très flexibles sans beaucoup de configuration. En pla?ant des éléments sur l'une des axes (ligne ou colonne) en utilisant Si l'élément déborde du conteneur, l'utilisation de la méthode
<li>
<li>
auto-fill
, vous pouvez facilement regrouper les éléments sélectionnés dans des conteneurs de grille sans affecter la disposition des éléments non sélectionnés dans le même récipient, tant que les éléments sélectionnés ne débordent pas du conteneur. span
aide à maintenir la disposition quelle que soit la longueur de l'élément sélectionné sur l'axe donné. Certaines alternatives de conception à l'interface utilisateur incluent le regroupement des éléments sélectionnés à la fin d'une liste, ou l'échange de structures horizontales et verticales.
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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
échangez les visages dans n'importe quelle vidéo sans effort grace à notre outil d'échange de visage AI entièrement gratuit?!

Article chaud

Outils chauds

Bloc-notes++7.3.1
éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

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

Sujets chauds









CSS bloque le rendu de la page car les navigateurs affichent le CSS en ligne et le CSS externe comme des ressources clés par défaut, en particulier avec les feuilles de styles importées, les grandes quantités de CSS en ligne et les styles de requête multimédia non optimisés. 1. Extraire CSS critique et l'intégrez-la dans HTML; 2. Retard Chargement CSS non critique via JavaScript; 3. Utilisez des attributs multimédias pour optimiser le chargement tel que les styles d'impression; 4. Comprimer et fusionner CSS pour réduire les demandes. Il est recommandé d'utiliser des outils pour extraire les CS de clé, combiner le chargement asynchrone rel = "précharge" et utiliser le chargement retardé des médias raisonnablement pour éviter une division excessive et un contr?le de script complexe.

AutoPrefixer est un outil qui ajoute automatiquement les préfixes des fournisseurs aux attributs CSS en fonction de la portée du navigateur cible. 1. Il résout le problème de maintenir manuellement les préfixes avec des erreurs; 2. Travaillez le formulaire de plug-in PostCSS, analyse CSS, analysez les attributs qui doivent être préfixés et générer du code en fonction de la configuration; 3. Les étapes d'utilisation incluent l'installation de plug-ins, la définition de la liste de navigateurs et leur permettant dans le processus de construction; 4. Les notes ne comprennent pas manuellement les préfixes, le maintien des mises à jour de la configuration, les préfixes pas tous des attributs, et il est recommandé de les utiliser avec le préprocesseur.

TOCREATESTICKYHEADERSERSANDFOOTERS WITHCSS, USEPOSITION: StickyforhederswithTopValueAndz-Index, assurant leparentContainerson’trestrictit.1.Forstickyheders: SetPosition: Sticky, Top: 0, Z-index, AndbackgroundColor.2

THECONCON-GRADIENT () FURMATINGEnSSSCREATSCICLULARD GRODIENTSTHATATATECOLORSTOPSAROUNDacentralpoint.1.IiSIDEALFORPIECHARTS, PROGRESSINDICATEURS, Colorweels, andDecorativeBackgrounds.2.itworksByDefiningColOrStopSatSpiecificangles, FactuallylyTartingfromadefinin

La portée des propriétés personnalisées de CSS dépend du contexte de leur déclaration, les variables globales sont généralement définies dans: Root, tandis que les variables locales sont définies dans un sélecteur spécifique pour la composontisation et l'isolement des styles. Par exemple, les variables définies dans la classe de cartes. Ne sont disponibles que pour des éléments qui correspondent à la classe et à leurs enfants. Les meilleures pratiques incluent: 1. Utilisation: racine pour définir des variables globales telles que la couleur du sujet; 2. Définir les variables locales à l'intérieur du composant pour implémenter l'encapsulation; 3. évitez de déclarer à plusieurs reprises la même variable; 4. Faites attention aux problèmes de couverture qui peuvent être causés par la spécificité du sélecteur. De plus, les variables CSS sont sensibles à la casse et doivent être définies avant utilisation pour éviter les erreurs. Si la variable n'est pas définie ou si la référence échoue, la valeur de retour ou la valeur par défaut initiale sera utilisée. Le débogage peut être fait par le biais du développeur du navigateur

Mobile-FirstcssDesigrequequetsettingTheViewportMetatag, UsingrelativeUnits, StylingFromsMallScreensup, OptimizingTypographicAndTouchtarget.First, addtiControlsaling.second, use%, em, orreminsteadofpixel

Il existe trois fa?ons de créer un rotateur de chargement CSS: 1. Utilisez le rotateur de base des frontières pour obtenir une animation simple via HTML et CSS; 2. Utilisez un rotateur personnalisé de plusieurs points pour atteindre l'effet de saut à travers différents temps de retard; 3. Ajoutez un rotateur dans le bouton et basculez les classes via JavaScript pour afficher l'état de chargement. Chaque approche souligne l'importance des détails de conception tels que la couleur, la taille, l'accessibilité et l'optimisation des performances pour améliorer l'expérience utilisateur.

Pour rendre l'intégralité de la disposition de la grille centrée dans la fenêtre, elle peut être réalisée par les méthodes suivantes: 1. Utilisez la marge: 0Auto pour atteindre le centrage horizontal, et le conteneur doit être défini pour définir la largeur fixe, qui convient à la mise en page fixe; 2. Utilisez Flexbox pour définir les propriétés de justification et d'alignement des éléments dans le récipient extérieur, et combinez la hauteur min: 100VH pour atteindre le centrage vertical et horizontal, qui convient aux scénarios d'affichage plein écran; 3. Utilisez la propriété Place-Items de CSSGrid pour se concentrer rapidement sur le conteneur parent, ce qui est simple et a un bon soutien des navigateurs modernes, et en même temps, il est nécessaire de garantir que le conteneur parent a une hauteur suffisante. Chaque méthode a des scénarios et des restrictions applicables, choisissez simplement la solution appropriée en fonction des besoins réels.
