CSS:nth-child() 疑似クラスは、兄弟要素のグループの中で1つまたは複数の要素を位置に基づいて選択します。

/* 兄弟要素の中で3つおきに
   要素を選択 */
:nth-child(4n) {
  color: lime;
}

構文

nth-child 疑似クラスは、要素を選択するパターンを表す引数を1つ取ります。

キーワード値

odd
一連の兄弟要素の中で奇数番目の要素(1, 3, 5, など)を表します。
even
一連の兄弟要素の中で偶数番目の要素(2, 4, 6, など)を表します。

関数表記

<An+B>
一連の兄弟要素の中で、 n に正の整数か0が入るとき、 An+B のパターンに一致する位置の要素を表します。最初の要素の番号は 1 です。 AB の値は両方とも <integer> です。

形式文法

:nth-child( <nth> [ of <selector># ]? )

where
<nth> = <an-plus-b> | even | odd

セレクターの例

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)
7番目の要素を表します。
:nth-child(5n)
5、10、15番目などの要素を表します。
:nth-child(3n+4)
4、7、10、13番目などの要素を表します。
:nth-child(-n+3)
兄弟要素のグループの中で最初の3つの要素を表します。
p:nth-child(n)
兄弟要素のグループの中ですべての <p> 要素を表します。これは単純な p セレクターと同じです。
p:nth-child(1) または p:nth-child(0n+1)
兄弟要素のグループの中で最初の <p> 要素すべてを表します。これは :first-child セレクターと同じです。

詳細なサンプル

HTML

<h3><code>span:nth-child(2n+1)</code>, WITHOUT an
   <code>&lt;em&gt;</code> among the child elements.</h3>
<p>Children 1, 3, 5, and 7 are selected.</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>, WITH an
   <code>&lt;em&gt;</code> among the child elements.</h3>
<p>Children 1, 5, and 7 are selected.<br>
   3 is used in the counting because it is a child, but it isn't
   selected because it isn't a <code>&lt;span&gt;</code>.</p>
<div class="second">
  <span>Span!</span>
  <span>Span</span>
  <em>This is an `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>, WITH an
   <code>&lt;em&gt;</code> among the child elements.</h3>
<p>Children 1, 4, 6, and 8 are selected.<br>
   3 isn't used in the counting or selected because it is an <code>&lt;em&gt;</code>, 
   not a <code>&lt;span&gt;</code>, and <code>nth-of-type</code> only selects
   children of that type. The <code>&lt;em&gt;</code> is completely skipped
   over and ignored.</p>
<div class="third">
  <span>Span!</span>
  <span>Span</span>
  <em>This is an `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;
}

.first span:nth-child(2n+1),
.second span:nth-child(2n+1),
.third span:nth-of-type(2n+1) {
  background-color: lime;
}

結果

仕様書

仕様書 策定状況 コメント
Selectors Level 4
:nth-child の定義
草案 <selector> の構文と仕様書に、親を持たない要素も一致するよう追加。
Selectors Level 3
:nth-child の定義
勧告 初回定義。

ブラウザー実装状況

機能ChromeEdgeFirefoxInternet ExplorerOperaSafari
基本対応1 あり3.599.513.1
of <selector> syntax なし ? なし2 ? ? ?
Matches elements with no parent57 ?52 ?44 ?
機能Android webviewChrome for AndroidEdge mobileFirefox for AndroidOpera AndroidiOS SafariSamsung Internet
基本対応 あり あり あり49.513.1 あり
of <selector> syntax ? ? ? なし2 ? ? なし
Matches elements with no parent5757 ?5244 ?7.0

1. Before Opera 15, Opera does not handle dynamically inserted elements for :nth-child().

2. See bug 854148.

関連項目

ドキュメントのタグと貢献者

 このページの貢献者: mfuji09, ethertank, sosleepy
 最終更新者: mfuji09,