--- title: ':nth-child' slug: 'Web/CSS/:nth-child' tags: - CSS - Layout - Reference - Web - Псевдоклассы translation_of: 'Web/CSS/:nth-child' ---
CSS псевдокласс :nth-child() находит один или более элементов, основываясь на их позиции среди группы соседних элементов.
/* Выбирает каждый четвёртый элемент
среди любой группы соседних элементов */
:nth-child(4n) {
color: lime;
}
Псевдокласс nth-child указывается с единственным аргументом, описывающим паттерн для выбирания элементов.
oddeven<An+B>An+B (для каждого целого числа n >= 0). Нумерация элементов начинается с единицы. Значения A и B должны быть {{cssxref("<integer>")}}s.tr:nth-child(odd) или tr:nth-child(2n+1)tr:nth-child(even) or tr:nth-child(2n):nth-child(7):nth-child(5n):nth-child(3n+4):nth-child(-n+3)p:nth-child(n)<p> среди группы соседних элементов. Эквивалентно простому селектору p.p:nth-child(1) или p:nth-child(0n+1)<p>, являющийся первым среди группы соседних элементов. Эквивалентно селектору {{cssxref(":first-child")}}.<h3><code>span:nth-child(2n+1)</code>, БЕЗ элемента <code><em></code> в группе элементов-потомков.</h3> <p>Элементы 1, 3, 5 и 7 будут выбраны.</p> <div class="first"> <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>, С элементом <code><em></code> в группе элементов-потомков.</h3> <p>Элементы 1, 5 и 7 будут выбраны.<br> 3 используется в подсчёте потому что это элемент-потомок, но он не выбран потому что он не <code><span></code>.</p> <div class="second"> <span>Span!</span> <span>Span</span> <em>Это `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>, С элементом <code><em></code> в группе элементов-потомков.</h3> <p>Элементы 1, 4, 6 и 8 будут выбраны.<br> 3 не используется в подсчёте и не выбран, потому что это <code><em></code>, но не <code><span></code>, а <code>nth-of-type</code> выбирает только потомков этого типа. Элемент <code><em></code> полностью пропускается и игнорируется.</p> <div class="third"> <span>Span!</span> <span>Span</span> <em>Это `em`.</em> <span>Span!</span> <span>Span</span> <span>Span!</span> <span>Span</span> <span>Span!</span> </div>
html {
font-family: sans-serif;
}
span,
div em {
padding: 5px;
border: 1px solid green;
display: inline-block;
margin-bottom: 3px;
}
.first span:nth-child(2n+1),
.second span:nth-child(2n+1),
.third span:nth-of-type(2n+1) {
background-color: lime;
}
{{EmbedLiveSample('Подробный_пример', 550, 550)}}
| Спецификация | Статус | Комментарий |
|---|---|---|
| {{SpecName('CSS4 Selectors', '#nth-child-pseudo', ':nth-child')}} | {{Spec2('CSS4 Selectors')}} | Добавление синтаксиса of <selector>, также теперь выбранные элементы не обязательно должны иметь родителя. |
| {{SpecName('CSS3 Selectors', '#nth-child-pseudo', ':nth-child')}} | {{Spec2('CSS3 Selectors')}} | Изначальное определение. |
{{Compat("css.selectors.nth-child")}}