Próbuję stylizować liczby na uporządkowanej liście, chciałbym dodać kolor tła, promień obramowania i kolor, aby pasowały do projektu, nad którym pracuję:
Myślę, że nie jest to możliwe i będę musiał użyć różnych obrazów dla każdego numeru, tj
ol li:first-child {list-style-image:url('1.gif')};
ol li:nth-child(2) {list-style-image:url('2.gif');}
etc...
Czy istnieje prostsze rozwiązanie?
html
css
html-lists
sprite
Pixelomo
źródło
źródło
Odpowiedzi:
Możesz to zrobić za pomocą liczników CSS w połączeniu z
:before
pseudoelementem:ol { list-style: none; counter-reset: item; } li { counter-increment: item; margin-bottom: 5px; } li:before { margin-right: 10px; content: counter(item); background: lightblue; border-radius: 100%; color: white; width: 1.2em; text-align: center; display: inline-block; }
<ol> <li>item</li> <li>item</li> <li>item</li> <li>item</li> </ol>
źródło
counter-reset: item;
Powinien iść w bloku ol, w przeciwnym razie licznik nie zostanie zresetowany w zagnieżdżonych <ol>.li
elementu składa się z więcej niż jednej linii?50%
forborder-radius
(zamiast100%
) jest wystarczająca, aby uzyskać okrąg. (Patrz np. Lea Verou, „ The curious case of border-radius: 50% ”, 30 października 2010 r.)li
position: relative;
, a potem:before
to,position: absolute;
a następnie użyjtop
i ustawleft
dokładnie tak, jak chcesz.Szukałem czegoś innego i znalazłem ten przykład w CodePen;
spróbuj tego: http://codepen.io/sawmac/pen/txBhK
body { font-size: 1.2em; font-family: "Helvetica Neue", Helvetica, sans-serif; margin: 50px; } .custom-counter { margin: 0; padding: 0; list-style-type: none; } .custom-counter li { counter-increment: step-counter; margin-bottom: 5px; } .custom-counter li::before { content: counter(step-counter); margin-right: 20px; font-size: 80%; background-color: rgb(180, 180, 180); color: white; font-weight: bold; padding: 3px 8px; border-radius: 11px; }
<ol class="custom-counter"> <li>This is the first item</li> <li>This is the second item</li> <li>This is the third item</li> <li>This is the fourth item</li> <li>This is the fifth item</li> <li>This is the sixth item</li> </ol>
źródło