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

黄舟
リリース: 2017-06-01 10:41:29
オリジナル
1699 人が閲覧しました

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) は

  • one
  • ノードを選択し、.demo li:nth-of-type(2) は
  • two
  • ノードを選択します。

    しかし、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 サイトの他の関連記事を参照してください。

    関連ラベル:
    ソース:php.cn
    このウェブサイトの声明
    この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
    人気のチュートリアル
    詳細>
    最新のダウンロード
    詳細>
    ウェブエフェクト
    公式サイト
    サイト素材
    フロントエンドテンプレート
    私たちについて 免責事項 Sitemap
    PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!