ホームページ >ウェブフロントエンド >CSSチュートリアル >私の n 番目の子セレクターがソーシャル アイコンで機能しないのはなぜですか?

私の n 番目の子セレクターがソーシャル アイコンで機能しないのはなぜですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-10-30 10:13:02943ブラウズ

Why Isn't My nth-child Selector Working on Social Icons?

n 番目の子セレクターが機能しない: その理由と修正方法

n 番目の子セレクターは、次の要素に基づいて要素を選択するための強力なツールです。親要素内での位置。ただし、セレクターが期待どおりに機能しない理由が混乱することがあります。

提供されたコードの場合、n 番目の子セレクターは、#social- 内のソーシャル アイコンに異なる背景画像を適用するために使用されます。リンク部n 番目の子の条件にもかかわらず、すべてのアイコンが同じように表示されます。この問題は、セレクターの仕組みについての誤解から生じています。

nth-child の仕組み

nth-child セレクターは、同じ親要素を共有する兄弟要素をカウントします。提供された HTML では、各 div.social-logo はそのアンカー タグの唯一の子です。したがって、n 番目の子セレクターは、指定された値に関係なく、1 つの要素のみをカウントします。

ただし、#social-links 内のアンカー タグは互いに兄弟です。その結果、n 番目の子セレクターは、次の構文を使用して個々のアンカー タグを効果的にターゲットにすることができます。

<code class="css">#social-links a:nth-child(1) div
#social-links a:nth-child(2) div
#social-links a:nth-child(3) div</code>

div 子要素の代わりにアンカー タグをターゲットにすることで、n 番目の子セレクターは次の要素を区別できるようになりました。

解決策

問題を解決するには、元の nth-child 宣言を次のものに置き換えます:

<code class="css">#social-links a:nth-child(1) div {
    background-image: url(...);
}

#social-links a:nth-child(2) div {
    background-image: url(...);
}

#social-links a:nth-child(3) div {
    background-image: url(...);
}</code>

ターゲット指定 タグを使用すると、n 番目の子セレクターは、意図したとおりに各ソーシャル アイコンに異なる背景画像を正しく適用します。

以上が私の n 番目の子セレクターがソーシャル アイコンで機能しないのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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