:nth-child()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
A pseudo-classe CSS :nth-child()
seleciona elementos com base em suas posições em um grupo de elementos irmãos.
/* Seleciona um a cada quatro elementos
de qualquer grupo de elementos irmãos,
começando do quarto elemento (4, 8 12, etc.). */
:nth-child(4n) {
color: lime;
}
Sintaxe
A pseudo-classe nth-child
é usada com apenas um argumento, que representa o padrão usado para selecionar os elementos.
Valores
Notação funcional
Sintaxe formal
Exemplos
Exemplos de seletores
tr:nth-child(odd)
ortr:nth-child(2n+1)
-
Representa as linhas ímpares de uma tabela HTML: 1, 3, 5, etc.
tr:nth-child(even)
ortr:nth-child(2n)
-
Representa as linhas pares de uma tabela HTML: 2, 4, 6, etc.
:nth-child(7)
-
Representa o sétimo elemento.
:nth-child(5n)
-
Representa os elementos de número 5 [=5×1], 10 [=5×2], 15 [=5×3], etc.
:nth-child(3n+4)
-
Representa os elementos de número 4 [=(3×0)+4], 7 [=(3×1)+4], 10 [=(3×2)+4], 13 [=(3×3)+4], etc.
:nth-child(-n+3)
-
Representa os primeiros três elementos. [=-0+3, -1+3, -2+3]
p:nth-child(n)
-
Representa todos os elementos
<p>
em um grupo de irmãos. Isso seleciona os mesmos elementos que um simples seletorp
faria (só que com um nível maior de especificidade). p:nth-child(1)
orp:nth-child(0n+1)
-
Representa todo
<p>
que seja o primeiro de seu grupo de irmãos. Ele é idêntico ao seletor:first-child
(e tem o mesmo nível de especificidade). p:nth-child(n+8):nth-child(-n+15)
-
Representa do 8º até o 15º elementos
<p>
de um grupo de irmãos.
Exemplo detalhado
HTML
<h3>
<code>span:nth-child(2n+1)</code>, SEM um <code><em></code> entre os
elementos filhos.
</h3>
<p>Os filhos 1, 3, 5 e 7 são selecionados.</p>
<div class="primeiro">
<span>Span 1!</span>
<span>Span 2</span>
<span>Span 3!</span>
<span>Span 4</span>
<span>Span 5!</span>
<span>Span 6</span>
<span>Span 7!</span>
</div>
<br />
<h3>
<code>span:nth-child(2n+1)</code>, COM um <code><em></code> entre os
elementos filhos.
</h3>
<p>
Os filhos 1, 5 e 7 são selecionados.<br />
O 3 está incluído na contagem por ser um filho, mas não é selecionado porque
ele não é um <code><span></code>.
</p>
<div class="segundo">
<span>Span!</span>
<span>Span</span>
<em>Este é um `em`.</em>
<span>Span</span>
<span>Span!</span>
<span>Span</span>
<span>Span!</span>
<span>Span</span>
</div>
<br />
<h3>
<code>span:nth-of-type(2n+1)</code>, COM um <code><em></code> entre os
elementos filhos.
</h3>
<p>
Os filhos 1, 4, 6 e 8 são selecionados.<br />
O 3 não está incluso na contagem nem é selecionado porque ele é um
<code><em></code>, não um <code><span></code>, e
<code>nth-of-type</code> seleciona apenas os filhos desse último tipo. O
<code><em></code> é completamente pulado e ignorado.
</p>
<div class="terceiro">
<span>Span!</span>
<span>Span</span>
<em>Este é um `em`.</em>
<span>Span!</span>
<span>Span</span>
<span>Span!</span>
<span>Span</span>
<span>Span!</span>
</div>
CSS
html {
font-family: sans-serif;
}
span,
div em {
padding: 5px;
border: 1px solid green;
display: inline-block;
margin-bottom: 3px;
}
.primeiro span:nth-child(2n + 1),
.segundo span:nth-child(2n + 1),
.terceiro span:nth-of-type(2n + 1) {
background-color: lime;
}
Resultado
Especificações
Specification |
---|
Selectors Level 4 # nth-child-pseudo |
Compatibilidade com navegadores
BCD tables only load in the browser