:nth-child()
Псевдоклас CSS :nth-child()
(дочірній номер N) дає збіг з елементами на основі їхніх індексів у списку дочірніх елементів їхніх батьківських елементів. Інакше кажучи, селектор :nth-child()
вибирає дочірні елементи згідно з їхніми позиціями серед усіх сестринських елементів у батьківському елементі.
Спробуйте його в дії
[!NOTE] В записі
element:nth-child()
підрахунок дочірніх елементів включає дочірні елементи усіх типів; проте збіг вважається збігом лише тоді, коли елемент на відповідній дочірній позиції дає збіг з рештою компонент селектора.
Синтаксис
:nth-child()
приймає єдиний аргумент, що описує патерн для пошуку збігу серед індексів елементів у списку дочірніх. Індекси елементів починаються з 1.
:nth-child( <nth> [ of <complex-selector-list> ]? )
Значення – ключові слова
odd
(непарний)Представляє елементи, чия числова позиція в наборі дочірніх елементів – непарна: 1, 3, 5 тощо.
even
(парний)Представляє елементи, чия числова позиція в наборі дочірніх елементів – парна: 2, 4, 6 тощо.
Функційний запис
<An+B>
Представляє елементи, чий номер місця в наборі сестринських елементів дає збіг з патерном
An+B
для кожного невід'ємного значенняn
, де:A
– цілий числовий крок,B
– цілий числовий відступ,n
– всі невід'ємні цілі числа, починаючи від 0.
Такий запис можна читати так: елемент списку номер
An+B
. ІA
, іB
– мусять мати значення типу<integer>
.
Запис of <selector>
Шляхом передачі селектора як аргументу можна вибрати nth (n-ний) елемент, що відповідає цьому селектору. Наприклад, наступний селектор відповідає першим трьом елементам списку, які мають class="important"
.
:nth-child(-n+3 of li.important);
Це відрізняється від переміщення селектора за межі функції, як у наступному прикладі:
li.important:nth-child(-n + 3) {
}
Цей селектор вибирає елементи списку, якщо вони є серед перших трьох дочірніх елементів і відповідають селектору li.important
.
Приклади
Приклади селекторів
tr:nth-child(odd)
чиtr:nth-child(2n+1)
Представляє непарні ряди таблиці HTML: 1, 3, 5 тощо.
tr:nth-child(even)
чиtr:nth-child(2n)
Представляє парні ряди таблиці HTML: 2, 4, 6 тощо.
:nth-child(7)
Представляє сьомий елемент.
:nth-child(5n)
Представляє елементи номер 5 [=5×1], 10 [=5×2], 15 [=5×3] тощо. Перше значення, повернене як результат формули, – 0 [=5x0], що не дасть збігу, адже елементи індексуються від 1, тим часом
n
починається від 0. Це може здаватися, на перший погляд, дивним, але має більше змісту, коли врахувати, що частина формулиB
–>0
, як в наступному прикладі.:nth-child(n+7)
Представляє сьомий і всі наступні елементи: 7 [=0+7], 8 [=1+7], 9 [=2+7] тощо.
:nth-child(3n+4)
Представляє елементи 4 [=(3×0)+4], 7 [=(3×1)+4], 10 [=(3×2)+4], 13 [=(3×3)+4] тощо.
:nth-child(-n+3)
Представляє перші три елементи. [=-0+3, -1+3, -2+3]
p:nth-child(n)
Представляє кожний елемент
<p>
у групі сестринських елементів. Такий запис вибирає ті самі елементи, що й простий селекторp
(але має вищу за нього специфічність).p:nth-child(1)
чиp:nth-child(0n+1)
Представляє кожний
<p>
, котрий є першим елементом в групі сестринських. Це те саме, що селектор:first-child
(з такою само специфічністю).p:nth-child(n+8):nth-child(-n+15)
Представляє елементи
<p>
в групі сестринських – від восьмого до п'ятнадцятого.
Розгорнутий приклад
HTML
<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>
CSS
.first span:nth-child(2n + 1),
.second span:nth-child(2n + 1),
.third span:nth-of-type(2n + 1) {
background-color: tomato;
}
Результат
Застосування 'of <selector>'
У цьому прикладі присутній невпорядкований список імен, деякі з яких були позначені (noted) за допомогою class="noted"
. Вони були виділені товстою нижньою межею.
HTML
<ul>
<li class="noted">Найден</li>
<li>Домінік</li>
<li class="noted">Щастибог</li>
<li>Арсена</li>
<li>Наслава</li>
<li>Йовілла</li>
<li class="noted">Колодара</li>
<li>Держислав</li>
<li>Орест</li>
<li class="noted">Віталія</li>
<li>Георгій</li>
<li>Уличан</li>
<li>Феодосія</li>
<li class="noted">Барбара</li>
<li>Ілля</li>
<li>Осипа</li>
<li class="noted">Трояна</li>
<li>Царук</li>
<li>Колодій</li>
<li class="noted">Ядвіга</li>
</ul>
CSS
В наступному CSS обираються парні елементи списку, які мають class="noted"
.
li:nth-child(even of .noted) {
background-color: tomato;
border-bottom-color: seagreen;
}
Результат
Елементи з class="noted"
мають товсту нижню межу, а елементи 3, 10 і 17 мають суцільний фон, оскільки вони є парними елементами списку з class="noted"
.
Запис of selector і запис selector nth-child
У цьому прикладі присутні два невпорядковані списки імен. Перший показує дію li:nth-child(-n + 3 of .noted)
, а другий – дію li.noted:nth-child(-n + 3)
.
HTML
<ul class="one">
<li class="noted">Найден</li>
<li>Домінік</li>
<li class="noted">Щастибог</li>
<li>Арсена</li>
<li>Наслава</li>
<li>Йовілла</li>
<li class="noted">Колодара</li>
<li>Держислав</li>
<li>Орест</li>
<li class="noted">Віталія</li>
</ul>
<ul class="two">
<li class="noted">Найден</li>
<li>Домінік</li>
<li class="noted">Щастибог</li>
<li>Арсена</li>
<li>Наслава</li>
<li>Йовілла</li>
<li class="noted">Колодара</li>
<li>Держислав</li>
<li>Орест</li>
<li class="noted">Віталія</li>
</ul>
CSS
ul.one > li:nth-child(-n + 3 of .noted) {
background-color: tomato;
border-bottom-color: seagreen;
}
ul.two > li.noted:nth-child(-n + 3) {
background-color: tomato;
border-bottom-color: seagreen;
}
Результат
Перший список застосовує стиль до перших трьох елементів списку, що мають class="noted"
, незалежно від того, чи є вони першими трьома елементами списку загалом.
Другий список – застосовує стиль до елементів з class="noted"
, якщо вони є серед перших трьох елементів списку.
Використання of selector для виправлення смугастих таблиць
Звичайною практикою для таблиць є використання зебрових смуг – чергування світлих і темних кольорів фону для рядків, що полегшує читання таблиць і робить їх більш доступними. Якщо рядок прихований, смуги зливаються – і ефект псується. У цьому прикладі показано дві таблиці з прихованим (hidden
) рядком. Друга з них використовує of :not([hidden])
для обробки прихованих рядків.
HTML
<table class="broken">
<thead>
<tr><th>Ім'я</th><th>Вік</th><th>Країна</th></tr>
</thead>
<tbody>
<tr><td>Зофія</td><td>23</td><td>Польща</td></tr>
<tr><td>Олівія</td><td>48</td><td>США</td></tr>
<tr hidden><td>Ноа</td><td>36</td><td>Великобританія</td></tr>
<tr><td>Ноюс</td><td>27</td><td>Литва</td></tr>
<tr><td>Амелія</td><td>55</td><td>Канада</td></tr>
<tr><td>Лео</td><td>66</td><td>Фінляндія</td></tr>
</tbody>
</table>
<table class="fixed">
<thead>
<tr><th>Ім'я</th><th>Вік</th><th>Країна</th></tr>
</thead>
<tbody>
<tr><td>Зофія</td><td>23</td><td>Польща</td></tr>
<tr><td>Олівія</td><td>48</td><td>США</td></tr>
<tr hidden><td>Ноа</td><td>36</td><td>Великобританія</td></tr>
<tr><td>Ноюс</td><td>27</td><td>Литва</td></tr>
<tr><td>Амелія</td><td>55</td><td>Канада</td></tr>
<tr><td>Лео</td><td>66</td><td>Фінляндія</td></tr>
</tbody>
</table>
CSS
.broken > tbody > tr:nth-child(even) {
background-color: silver;
}
.fixed > tbody > tr:nth-child(even of :not([hidden])) {
background-color: silver;
}
Результат
У першій таблиці просто використовується :nth-child(even)
. Третій рядок має атрибут hidden
. Тому в цьому випадку третій рядок не видно, а другий і четвертий рядки вважаються парними, хоча візуально це не так.
У другій таблиці для вибору лише тих tr
, які не приховані за допомогою :nth-child(even of :not([hidden]))
, використовується запис of.
Стилізація колонки таблиці
Під час стилізації колонки таблиці не можна задати стилі елементу <col>
, адже комірки таблиці не є його дочірніми (як це можна робити для елемента ряду, <tr>
). Псевдокласи, як-от :nth-child()
, зручні для вибору всіх комірок однієї колонки.
У цьому прикладі задаються різні стилі для кожної з колонок.
HTML
<table>
<caption>Список студентів</caption>
<colgroup>
<col/>
<col/>
<col/>
</colgroup>
<thead>
<tr><th>Ім'я</th><th>Вік</th><th>Країна</th></tr>
</thead>
<tbody>
<tr><td>Мамітіана</td><td>23</td><td>Мадагаскар</td></tr>
<tr><td>Юкі</td><td>48</td><td>Японія</td></tr>
</tbody>
</table>
CSS
td {
padding: 0.125rem 0.5rem;
height: 3rem;
border: 1px solid black;
}
tr :nth-child(1) {
text-align: left;
vertical-align: bottom;
background-color: silver;
}
tbody tr :nth-child(2) {
text-align: center;
vertical-align: middle;
}
tbody tr :nth-child(3) {
text-align: right;
vertical-align: top;
background-color: tomato;
}
Результат
Специфікації
Специфікація |
---|
Selectors Level 4 (Selectors 4) # nth-child-pseudo |
Сумісність із браузерами
desktop | mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
:nth-child()
|
Chrome Full support 1 | Edge Full support 12 | Firefox Full support 3.5 | Internet Explorer Full support 9 | Opera Full support 9.5 | Safari Full support 3.1 | WebView Android Full support 37 | Chrome Android Full support 18 | Firefox for Android Full support 4 | Opera Android Full support 10.1 | Safari on iOS Full support 2 | Samsung Internet Full support 1.0 |
Matches elements with no parent
|
Chrome Full support 57 | Edge Full support 79 | Firefox Full support 52 | Internet Explorer No support Ні | Opera Full support 44 | Safari No support Ні | WebView Android Full support 57 | Chrome Android Full support 57 | Firefox for Android Full support 52 | Opera Android Full support 43 | Safari on iOS No support Ні | Samsung Internet Full support 7.0 |
of <selector> syntax
|
Chrome No support Ні | Edge No support Ні | Firefox No support Ні | Internet Explorer No support Ні | Opera No support Ні | Safari Full support 9 | WebView Android No support Ні | Chrome Android No support Ні | Firefox for Android No support Ні | Opera Android No support Ні | Safari on iOS Full support 9 | Samsung Internet No support Ні |
Дивіться також
:nth-of-type()
:nth-last-child()
:has()
– псевдоклас для вибору батьківського елемента- Псевдокласи деревної структури
- Модуль Селекторів CSS