recherche
Maisoninterface Webtutoriel CSSRegrouper les éléments de la liste de sélection avec la grille CSS

Grouping Selection List Items Together With CSS Grid

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 tâches, les éléments terminés montent vers le haut, ce qui facilite la concentration sur les tâches 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 HTML des deux méthodes est le même:

Le code

    <li> <li>
se compose d'une liste non ordonnée (

). 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

est utilisée pour le nombre de répétitions de la fonction

. 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)

Cela fait regrouper les éléments sélectionnés en haut de la liste et organisé horizontalement.
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

. Le nouveau style

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>

Chaque élément est placé dans la première colonne, mais maintenant ils couvrent également six pistes de colonne (car il y a six éléments). Cela garantit que lorsque plusieurs colonnes apparaissent dans la grille, les éléments non sélectionnés après l'élément sélectionné restent unique, en dessous de l'élément sélectionné - les éléments non sélectionnés couvrent désormais plusieurs pistes de colonnes.
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

La largeur de l'élément sélectionné a été augmentée pour afficher la disposition de l'interface utilisateur sélectionnée lorsque l'élément déborde du conteneur est sélectionné.
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é.


    <li> <li>

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 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.

Si l'élément déborde du conteneur, l'utilisation de la méthode 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!

Déclaration
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
Deux images et une API: tout ce dont nous avons besoin pour recolorer les produitsDeux images et une API: tout ce dont nous avons besoin pour recolorer les produitsApr 15, 2025 am 11:27 AM

J'ai récemment trouvé une solution pour mettre à jour dynamiquement la couleur de toute image de produit. Donc, avec un seul produit, nous pouvons le colorer de différentes manières pour montrer

Actualités hebdomadaires de la plate-forme: impact du code tiers, contenu mixte passif, pays avec les connexions les plus lentesActualités hebdomadaires de la plate-forme: impact du code tiers, contenu mixte passif, pays avec les connexions les plus lentesApr 15, 2025 am 11:19 AM

En cette semaine, le Roundup, Lighthouse met en lumière les scripts tiers, les ressources en insécurité seront bloquées sur des sites sécurisés et de nombreuses vitesses de connexion de pays

Options pour héberger vos propres analyses non-javascriptOptions pour héberger vos propres analyses non-javascriptApr 15, 2025 am 11:09 AM

Il existe de nombreuses plates-formes d'analyse pour vous aider à suivre les données des visiteurs et d'utilisation sur vos sites. Peut-être plus particulièrement Google Analytics, qui est largement utilisé

C'est tout dans la tête: gérer la tête de document d'un site alimenté par réact avec un casque ReactC'est tout dans la tête: gérer la tête de document d'un site alimenté par réact avec un casque ReactApr 15, 2025 am 11:01 AM

Le chef de document n'est peut-être pas la partie la plus glamour d'un site Web, mais ce qui y va est sans doute tout aussi important pour le succès de votre site Web que son

Qu'est-ce que Super () dans JavaScript?Qu'est-ce que Super () dans JavaScript?Apr 15, 2025 am 10:59 AM

Qu'est-ce qui se passe quand vous voyez un JavaScript qui appelle super () ?. Dans une classe d'enfants, vous utilisez super () pour appeler le constructeur et le super. pour accéder à son

Comparaison des différents types de popups JavaScript natifsComparaison des différents types de popups JavaScript natifsApr 15, 2025 am 10:48 AM

JavaScript possède une variété d'API popup intégrés qui affichent l'interface utilisateur spéciale pour l'interaction utilisateur. Fameusement:

Pourquoi les sites Web accessibles sont-ils si difficiles à construire?Pourquoi les sites Web accessibles sont-ils si difficiles à construire?Apr 15, 2025 am 10:45 AM

L'autre jour, je discutais avec des gens frontaux sur les raisons pour lesquelles tant d'entreprises ont du mal à créer des sites Web accessibles. Pourquoi les sites Web accessibles sont-ils si durs

L'attribut `` caché 'est visiblement faibleL'attribut `` caché 'est visiblement faibleApr 15, 2025 am 10:43 AM

Il y a un attribut HTML qui fait exactement ce que vous pensez qu'il devrait faire:

See all articles

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
4 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP

PhpStorm version Mac

PhpStorm version Mac

Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft

Dreamweaver Mac

Dreamweaver Mac

Outils de développement Web visuel