Estou tentando definir o estilo dos números em uma lista ordenada, gostaria de adicionar cor de fundo, raio de borda e cor para que correspondam ao design a partir do qual estou trabalhando:
Acho que não é possível e terei que usar imagens diferentes para cada número, ou seja,
ol li:first-child {list-style-image:url('1.gif')};
ol li:nth-child(2) {list-style-image:url('2.gif');}
etc...
Existe uma solução mais simples?
html
css
html-lists
sprite
Pixelomo
fonte
fonte
Respostas:
Você pode fazer isso usando contadores CSS , em conjunto com o
:before
pseudo elemento: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>
fonte
counter-reset: item;
deve ir para o bloco ol, caso contrário, o contador não será zerado no <ol> aninhado.li
elemento é mais de uma linha?50%
paraborder-radius
(em vez de100%
) é suficiente para obter um círculo. (Ver, por exemplo, Lea Verou, " The curious case of border-radius: 50% ", 30 de outubro de 2010.)li
position: relative;
, e então:before
você dariaposition: absolute;
e então usariatop
eleft
posicionaria exatamente como você gostaria.Eu estava procurando por algo diferente e encontrei este exemplo na CodePen;
tente isto: 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>
fonte