ホームページ  >  記事  >  ウェブフロントエンド  >  CSS3のnth-childとnth-of-typeの違いを詳しく解説

CSS3のnth-childとnth-of-typeの違いを詳しく解説

黄舟
黄舟オリジナル
2017-06-01 10:41:291700ブラウズ

CSS3 における nth-child と nth-of-type の違いは、実際には非常に単純です。なぜ :nth-of-type は :nth-of-type と呼ばれるのでしょうか?それは「種類」で区別しているからです。つまり、ele:nth-of-type(n) は親要素の下の n 番目の ele 要素を指し、ele:nth-child(n) は親要素の下の n 番目の要素を指し、この要素は ele です。そうでない場合、選択は失敗します。

テキストは少し難解に聞こえるかもしれませんが、理解しやすいです。 ここに小さな例を示します:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>demo</title>
</head>
<style>
.demo li:nth-child(2){
color: #ff0000;
}
.demo li:nth-of-type(2){
color: #00ff00;
}
</style>
<body>
<p>
<ul class="demo">
<p>zero</p>
<li>one</li>
<li>two</li>
</ul>
</p>
</body>
</html>


結果は次のとおりです:

CSS3のnth-childとnth-of-typeの違いを詳しく解説

上記の例では、 .demo li:nth- child(2) は 25edfb22a4f469ecb59f1190150159c6onebed06894275b65c1ab86501b08a632eb ノードを選択し、.demo li:nth-of-type(2) は 25edfb22a4f469ecb59f1190150159c6twobed06894275b65c1ab86501b08a632eb ノードを選択します。

しかし、nth-child と nth-of-type の前にタグが指定されていない場合はどうなるでしょうか?

.demo :nth-child(2){
color: #ff0000;
}
.demo :nth-of-type(2){
color: #00ff00;
}


結果はどうなるでしょうか? HTML 構造を見てください:

<ul class="demo">
<p>first p</p>
<li>first li</li>
<li>second li</li>
<p>second p</p>
</ul>


結果:

CSS3のnth-childとnth-of-typeの違いを詳しく解説

上でわかるように、タグの型はその前に指定されていません: nth-child( 2) selected ラベルが何であっても、これは依然として 2 番目の要素です。そして、:nth-type-of(2) は、parent.demo の 2 番目の p タグと 2 番目の li タグの 2 つの要素を選択します。タグのタイプが指定されていない場合は、:nth-type -of であることがわかります。 (2) は、すべての type タグの 2 番目を選択します。

nth-child と nth-of-type の基本的な使い方と違いはすでに理解しました。それでは、nth-of-type(n) と nth-child(n) の n は何でしょうか?

nth-of-type(n) および nth-child(n) n には、数値、キーワード、または式を指定できます。 数字: これは上記の例の使用法なので、詳細は説明しません。 キーワード: 奇数、偶数

奇数と偶数は、添字が奇数または偶数である子要素と一致するために使用できるキーワードです
​​
注: 最初の子要素の添字は 1 です

ここでは、奇数と偶数です。 p 要素でも 2 つの異なる背景色を指定します:

p:nth-of-type(odd)
{
background:#ff0000;
}
p:nth-of-type(even)
{
background:#0000ff;
}

式: または、式 (an + b) を使用した算術

。説明: 期間の長さを示します。n はカウンタ (0 から始まります)、b はオフセット値です。

ここでは、添字が 3 の倍数であるすべての p 要素の背景色を指定します:

p:nth-of-type(3n+0)
{
background:#ff0000;
}

それが: nth-of-type(4n+2) の場合、添字が 4 の倍数であることを意味しますプラス 2 すべての要素の概要




以上がCSS3のnth-childとnth-of-typeの違いを詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。