recherche
Maisoninterface Webtutoriel CSSComment ajouter des virgules entre une liste d'éléments dynamiquement avec CSS

Comment ajouter des virgules entre une liste d'éléments dynamiquement avec CSS

Supposons que vous ayez une liste d'éléments tels que les fruits: bananes, pommes, oranges, poires, nectarines.

Nous pouvons ajouter des virgules (,) directement dans HTML, mais voyons comment il peut être mis en œuvre dans CSS, ce qui nous donne plus de contrôle. Dans le même temps, nous devons également nous assurer que le dernier élément n'a pas de virgule.

J'ai récemment besoin de cette fonctionnalité dans un vrai projet, une partie de l'exigence est que tout projet de la liste peut être masqué / affiché via JavaScript. Indépendamment de quels éléments sont actuellement affichés, la virgule doit être affichée correctement.

Une solution plutôt élégante que j'ai trouvée consiste à utiliser un combinateur de frères et sœurs universels. Nous en discuterons plus tard. Commençons par un exemple de HTML. Supposons que vous commencez par une liste de fruits:

<code></code>
  • banane
  • pomme
  • orange
  • poire
  • nectarine

Et quelques CS de base pour le faire apparaître comme une liste:

 .fruits {
  Affichage: flex;
  rembourrage en ligne: 0;
  Style de liste: aucun;
}

.fruit {
  Affichage: aucun; / * Masquer par défaut * /
} 
.fruit.on {/ * classe ajoutée par JavaScript, utilisée pour afficher les éléments de liste * /
  Affichage: bloc en ligne;
}

Maintenant, supposons que quelque chose se passe à l'intérieur de cette interface, comme les commandes de changements d'utilisateur pour filtrer tous les fruits qui poussent dans les climats froids. Maintenant, les différents ensembles de fruits sont affichés, de sorte que la classe Fruit.on utilise l'API de la liste de classe pour fonctionner.

Jusqu'à présent, notre HTML et CSS créeront une liste comme ceci:

<code>香蕉橙子油桃</code>

Maintenant, nous pouvons ajouter des virgules et des espaces entre deux éléments sur des éléments à l'aide d'un combiner les frères universels:

 .fruit.on ~ .fruit.on :: avant {
  contenu: ', '; 
}

bien!

Vous vous demandez peut-être: pourquoi ne pas simplement appliquer une virgule à tous les éléments de liste, puis le supprimer du dernier élément avec quelque chose comme: dernier-enfant ou: dernier de type? Le problème avec cela est que le dernier élément enfant peut être dans un état "fermé" à tout moment. Donc, ce que nous voulons vraiment, c'est le dernier projet dans l'état "ouvert", qui n'est pas facile à mettre en œuvre dans CSS, car il n'y a pas de "dernier de classe" disponible. Par conséquent, des astuces de combinateur à usage général sont utilisées!

Dans l'interface utilisateur, j'ai utilisé la largeur maximale au lieu de l'affichage, et je l'ai basculé entre 0 et un maximum raisonnable afin que je puisse utiliser la transition pour afficher et masquer les éléments plus naturellement, ce qui permet aux utilisateurs de voir plus facilement les éléments qui sont ajoutés ou supprimés de la liste. Vous pouvez également ajouter le même effet au pseudo-élément pour le rendre super lisse.

Voici une démo avec quelques exemples légèrement différents. L'exemple de fruits utilise des classes cachées plutôt que sur les classes, tandis que l'exemple de légumes a des effets animés. SCSS est également utilisé pour la nidification:

J'espère que cela aide les autres à la recherche d'une solution similaire!

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
Demystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiquesDemystifier les lecteurs d'écran: formulaires accessibles et meilleures pratiquesMar 08, 2025 am 09:45 AM

Ceci est le 3ème article d'une petite série que nous avons faite sur l'accessibilité. Si vous avez manqué le deuxième article, consultez "Gestion de la mise au point des utilisateurs avec: Focus-visible". Dans

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

Ce tutoriel montre la création de formulaires JavaScript professionnels à l'aide du cadre Smart Forms (Remarque: non plus disponible). Bien que le cadre lui-même ne soit pas disponible, les principes et techniques restent pertinents pour d'autres constructeurs de formulaires.

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

Le CSS Box-Shadow et les propriétés de contour ont gagné le thème. Laissez regarder quelques exemples de la façon dont cela fonctionne dans des thèmes réels et des options que nous devons appliquer ces styles aux blocs et éléments WordPress.

Travailler avec GraphQL CachingTravailler avec GraphQL CachingMar 19, 2025 am 09:36 AM

Si vous avez récemment commencé à travailler avec GraphQL ou examiné ses avantages et ses inconvénients, vous avez sans aucun doute entendu des choses comme "GraphQL ne prend pas en charge la mise en cache" ou

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

L'API de transition Svelte fournit un moyen d'animer les composants lorsqu'ils entrent ou quittent le document, y compris les transitions Svelte personnalisées.

Barbars CSS personnalisés chics et cool: une vitrineBarbars CSS personnalisés chics et cool: une vitrineMar 10, 2025 am 11:37 AM

Dans cet article, nous plongerons dans le monde des barres de défilement. Je sais, ça ne semble pas trop glamour, mais croyez-moi, une page bien conçue va de pair

Show, ne dit pasShow, ne dit pasMar 16, 2025 am 11:49 AM

Combien de temps passez-vous à concevoir la présentation de contenu pour vos sites Web? Lorsque vous écrivez un nouveau blog ou créez une nouvelle page, pensez-vous à

Que diable sont les commandes NPM?Que diable sont les commandes NPM?Mar 15, 2025 am 11:36 AM

Les commandes NPM exécutent diverses tâches pour vous, soit en tant que processus unique ou en cours d'exécution pour des choses comme le démarrage d'un serveur ou la compilation de code.

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)
2 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
2 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

Adaptateur de serveur SAP NetWeaver pour Eclipse

Adaptateur de serveur SAP NetWeaver pour Eclipse

Intégrez Eclipse au serveur d'applications SAP NetWeaver.

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Version Mac de WebStorm

Version Mac de WebStorm

Outils de développement JavaScript utiles

VSCode Windows 64 bits Télécharger

VSCode Windows 64 bits Télécharger

Un éditeur IDE gratuit et puissant lancé par Microsoft