Astuce CSS : Personnaliser simplement vos listes à puces, sans image
Les listes à puces, c'est pratique, on peut s'en servir partout et cela permet de structurer rapidement et simplement des points clés.
De base, les CSS permettent de customiser rapidement et simplement les listes à puces, il est possible d'avoir des ronds, des carrés, ou de les transformer en liste numérotée. Mais tout cela reste très ... gris. Sinon, comme sur ce site, il est aussi possible d'utliser des images pour les égailler un peu.
Mais il existe une solution intermédiaire, qui permet d'approfondir la customisation des listes à puce sans avoir recours aux images.
La solution vient tout simplement de l'utilisation des pseudos classes, et en particulier "before".
Pour commencer, supprimons le symbole par défaut
ul {list-style:none;}
puis ajoutons notre symbole, par exemple, un signe moins, que l'on souhaite rouge dans la pseudo-classe "before" de nos éléments de liste.
ul {list-style:none;} li:before {content:"-"; color:red;}
et voila, c'est bien, mais cela n'est pas aussi parfait que l'on pourrait le souhaiter.
Afin de conserver un alignement des puces, en avant du contenu, nous allons forcé le déplacement de la puce
ul {list-style:none;} li:before {content:"-"; color:red; position:relative; left:-16px;}
La valeur de "left" devra être ajusté selon le design souhaité et la taille du caractère utilisé.
La puce peut alors sortir de son cadre, il faut donc déplacer l'ensemble de la puce vers la droite pour compenser.
ul {list-style:none;} li {padding-left:12px;} li:before {content:"-"; color:red; position:relative; left:-16px;}
La valeur de "padding-left" sera ajustée, en fonction de la valeur de "left" vue précédement.
Enfin pour terminer, il faut faire en sorte que le texte reste bien aligné, même lorsqu'il passe sur plusieurs lignes. Pour cela, il faut tricher un peu, en supprimant toute taille de notre puce personalisée ul {list-style:none;} li {padding-left:12px;} li:before {content:"-"; color:red; position:relative; left:-16px; width:0; overflow:visible; display:inline-block;}
Petit bonus, si vous voulez utiliser des caractères de type symboles, il ne suffit pas d'y mettre le caractère HTML. Par exemple, pour un tilde, cela ne marcherait pas
li:before {content:"&tild;";}
il faut utiliser son caractère au format hexadécimal
li:before {content:"0007E";}
Et pour ne pas se tromper, il suffit de prendre une page comme celle-ci, pour obtenir la valeur hexadécimale de votre caractère et lui mettre sa valeur complète tel que :
- 7E devient 0007E pour le tilde
ou encore
- 2022 devient 02022 pour le tilde