CSSの~(全般兄弟結合子)で、同じ親要素内の特定の要素の後に続く兄弟要素をすべて選択する方法をわかりやすく解説

スポンサーリンク

~ セレクタは「全般兄弟結合子」と呼ばれ、同じ親要素内で指定した要素の後に続くすべての兄弟要素に対してスタイルを適用します。つまり、ターゲットとする要素の後に存在するすべての兄弟要素が対象になります。

スポンサーリンク

CSS: ~ セレクタが効かない時の原因と対策

要素が兄弟要素ではない

~ セレクタは、指定した要素とターゲットが同じ親要素を持つ兄弟要素である場合にのみ機能します。もしターゲット要素が同じ親要素を持たない場合、スタイルは適用されません。

対策: HTML構造を確認し、ターゲットとする要素が正しく兄弟要素であるか確認してください。

セレクタの優先順位(特異性)が低い

他のより具体的なCSSセレクタが ~ セレクタよりも優先される場合、スタイルが適用されないことがあります。

対策: より具体的なセレクタを使用するか、!important を使用してスタイルを強制的に適用します。

共通するCSSコード

.css-sample-container {
  width: 80%;
  margin: 0 auto;
  padding: 10px;
  border: 1px solid #ccc;
  background-color: #f9f9f9;
  text-align: center;
  font-family: Arial, sans-serif;
}

表示例

CSS: ~ セレクタ

以下の例では、最初の要素の後に続くすべての兄弟要素に対して背景色が変更されます。

HTMLコード

<div class="css-sample-container">最初の要素</div>
<div class="css-sample-container">後に続く兄弟要素</div>
<div class="css-sample-container">さらに後に続く兄弟要素</div>

CSSコード

.css-sample-container ~ .css-sample-container {
  background-color: #e0f7fa;
}

結果

最初の要素
後に続く兄弟要素
さらに後に続く兄弟要素

まとめ

  • ~ セレクタは、指定した要素の後に続くすべての兄弟要素に対してスタイルを適用します。
  • 兄弟要素でない場合、スタイルは適用されません。
  • セレクタの優先順位やキャッシュの問題に注意する必要があります。