1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
|
---
title: ':nth-child'
slug: Web/CSS/:nth-child
translation_of: Web/CSS/:nth-child
---
{{CSSRef}}
La [pseudo-classe](/fr/docs/Web/CSS/Pseudo-classes) **`:nth-child(an+b)`** permet de cibler un élément qui possède `an+b-1` éléments voisins (au même niveau) avant lui dans l'arbre du document pour des valeurs entières `n` et qui possède un élément parent. Autrement dit, un sélecteur utilisant cette pseudo-classe permettra de cibler les éléments fils d'un élément dont les positions correspondent au motif _an+b_.
```css
/* Cible les éléments en fonction de leur position dans */
/* le document : ici le 4e, 8e, 16e, 20e, etc. quel que */
/* soit le type de l'élément */
body :nth-child(4n) {
background-color: lime;
}
```
> **Note :** Pour CSS3, pour que l'élément soit ciblé, il faut qu'il ait un élément parent. En CSS4, cette restriction a été levée.
Illustrons cela avec quelques exemples :
- `1n+0` ou `n` ciblera chaque élément fils. `n` ne cible aucun élément pour le navigateur Android jusqu'à la version 4.3 alors qu'`1n` fonctionne. `1n` est synonyme de `1n+0` et les deux peuvent donc être utilisés de façon équivalente.
- `2n+0` ou `2n` ciblera les éléments fils 2, 4, 6, 8, etc. On pourra utiliser le mot-clé **`even`** à la place de cette expression.
- `2n+1` ciblera les éléments fils 1, 3, 5, 7, etc. On pourra utiliser le mot-clé **`odd`** à la place de cette expression.
- `3n+4` permettra de cibler les éléments fils 4, 7, 10, 13, etc.
- `0n+3` (ou plus simplement `3`) permettra de cibler le troisième élément.
Les valeurs des coefficients `a` et `b` doivent être des entiers et l'indice du premier élément fils commence à 1. Autrement dit, cette pseudo-classe permettra de cibler les éléments fils dont l'indice appartient à l'ensemble `{ an + b; n = 0, 1, 2, ... }`.
Cette pseudo-classe pourra ainsi être utilisée pour mettre en forme certaines lignes d'un tableau.
## Syntaxe
La pseudo-classe `nth-child` prend un seul argument qui représente le motif de répétition des éléments ciblés.
### Valeurs avec un mot-clé
- `odd`
- : Représente les éléments dont la position est impaire par rapport à leurs voisins.
- `even`
- : Représente les éléments dont la position est paire par rapport à leurs voisins.
### Notation fonctionnelle
- `<An+B>`
- : Représente les éléments dont la position est la `An+B`-ième avec `n` qui parcourt les entiers à partir de 0. Les valeurs fournies pour `A` et `B` doivent être des entiers ({{cssxref("<integer>")}}).
### Syntaxe formelle
{{csssyntax}}
## Exemples
### Exemples de sélecteurs
- `tr:nth-child(2n+1)`
- : Permettra de cibler les lignes impaires d'un tableau.
- `tr:nth-child(odd)`
- : Permettra de cibler les lignes impaires d'un tableau.
- `tr:nth-child(2n)`
- : Permettra de cibler les lignes paires d'un tableau.
- `tr:nth-child(even)`
- : Permettra de cibler les lignes paires d'un tableau.
- `span:nth-child(0n+1)`
- : Permettra de cibler un élément {{HTMLElement("span")}} qui est le premier fils de son parent. Cela aura le même effet que la pseudo-classe {{cssxref(":first-child")}}.
- `span:nth-child(1)`
- : Synonyme à l'exemple précédent.
- `span:nth-child(-n+3)`
- : Permettra de cibler un élément si celui-ci fait partie des trois premiers fils d'un parent et que c'est également un élément `span`.
### Exemple démonstratif
#### CSS
```css
html {
font-family: sans-serif;
}
span, div em {
padding: 10px;
border: 1px solid green;
display: inline-block;
margin-bottom: 3px;
}
.premier span:nth-child(2n+1),
.deuxieme span:nth-child(2n+1),
.troisieme span:nth-of-type(2n+1) {
background-color: lime;
}
```
#### HTML
```html
<p>
<code>span:nth-child(2n+1)</code>,
<em>sans</em> un <code><em></code>
parmi les éléments. Les éléments fils 1, 3,
5 et 7 sont sélectionnés.
</p>
<div class="premier">
<span>Ce span est sélectionné !</span>
<span>Pas ce span ci. :(</span>
<span>Celui-ci ?</span>
<span>Celui-là ?</span>
<span>Un autre exemple</span>
<span>Et encore un</span>
<span>Puis un dernier</span>
</div>
<p>
<code>span:nth-child(2n+1)</code>,
<em>avec</em> un élément <code><em></code>
parmi les fils. Les éléments fils 1, 5,
et 7 sont sélectionnés. 3 est compté
mais n'est pas ciblé car ce n'est pas
<code><span></code>.
</p>
<div class="deuxieme">
<span>Ce span est sélectionné !</span>
<span>Pas ce span ci. :(</span>
<em>Ici on a un em.</em>
<span>Qu'en est-il de celui-ci ?</span>
<span>De celui-là ?</span>
<span>Voici un autre exemple</span>
<span>Et encore un</span>
<span>Puis un dernier</span>
</div>
<p>
<code>span:nth-of-type(2n+1)</code>,
<em>avec</em> un <code><em></code>
parmi les éléments fils. Les éléments fils
1, 4, 6 et 8 sont sélectionnés. 3 n'est pas
compté ni ciblé car c'est un <code><em></code>,
et pas un <code><span></code> et
<code>nth-of-type</code> ne sélectionne que les
fils de ce type. Ce <code><em></code> est
sauté et est ignoré.
</p>
<div class="troisieme">
<span>Ce span est sélectionné !</span>
<span>Pas ce span ci. :(</span>
<em>Ici on a un em.</em>
<span>Qu'en est-il de celui-ci ?</span>
<span>De celui-là ?</span>
<span>Voici un autre exemple</span>
<span>Et encore un</span>
<span>Puis un dernier</span>
</div>
```
#### Résultat
{{EmbedLiveSample('Exemple_démonstratif','100%', '550')}}
## Spécifications
| Spécification | État | Commentaires |
| ---------------------------------------------------------------------------------------- | ------------------------------------ | -------------------------------------------------------------------------------------------- |
| {{SpecName('CSS4 Selectors', '#nth-child-pseudo', ':nth-child')}} | {{Spec2('CSS4 Selectors')}} | Ajout de la syntaxe `<selector>`. Les éléments ciblés peuvent ne pas avoir d'élément parent. |
| {{SpecName('CSS3 Selectors', '#nth-child-pseudo', ':nth-child')}} | {{Spec2('CSS3 Selectors')}} | Définition initiale. |
## Compatibilité des navigateurs
{{Compat("css.selectors.nth-child")}}
## Voir aussi
- {{cssxref(":nth-of-type")}}
- {{cssxref(":first-child")}}
- {{cssxref(":last-child")}}
|