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

/* 兄弟要素の中で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番目 [=5×1], 10番目 [=5×2], 15番目 [=5×3], の要素を表します。
:nth-child(3n+4)
4番目 [=(3×0)+4], 7番目 [=(3×1)+4], 10番目 [=(3×2)+4], 13番目 [=(3×3)+4], の要素を表します。
:nth-child(-n+3)
兄弟要素のグループの中で最初の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)
兄弟要素のグループの中で8~15番目の <p> 要素を表します。

詳細な例

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 ? ?9
Matches elements with no parent57 ?52 ?44 ?
機能Android webviewChrome for AndroidEdge mobileFirefox for AndroidOpera AndroidiOS SafariSamsung Internet
基本対応 あり あり あり49.513.1 あり
of <selector> syntax ? ? ? なし2 ?9 なし
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,