*

div要素のクラス名をnth-childの擬似クラスで何番目を指定しても効かない

公開日: : ノウハウ

divタグ

CSS3 が登場して擬似クラス nth-child が使えるようになって、要素の何番目のみにスタイルを適用するような事が非常に簡単になりました。従来ではクラスなどを駆使して無理やり指定していました。これではソースも CSS も冗長になって美しくありません。nth-child が全てを解決してくれます。例として以下を御覧ください。

  • りんご
  • みかん
  • ぶどう

この2行目のみかんのみ文字色を変えたいという場合は css で nth-child を指定します。

ul li:nth-child(2){
   color:#f00;
}

nth-child(2) でリストの2番目を指定するという意味になります。

前置きはこのくらいにして、ここからが本題です。このような便利な nth-child ですが、div 要素に nth-child を指定した時に詰まりました。

クラス名の違うdivが連なる場合

このような html ソースがあるとしましょう。

<div class="top">
   トップ1
</div>
<div class="top">
   トップ2
</div>
<div class="bottom">
   ボトム1
</div>
<div class="bottom">
   ボトム2
</div>

ボトム1を指定したいので以下のような css にしました。

div.bottom:nth-child(1){
   color:#f00;
}

しかし、文字色は変わりませんでした。

div.top:nth-child(1){
   color:#f00;
}

上の方にあるクラス名 top を指定するとちゃんと文字色が変わります。ここで原因がわからず詰まっていたのです。

対処法

以下のようにすることでちゃんと目的の要素を指定できました。

<section>
   <div class="top">
      トップ1
   </div>
   <div class="top">
      トップ2
   </div>
</section>
<section>
   <div class="bottom">
      ボトム1
   </div>
   <div class="bottom">
      ボトム2
   </div>
</section>

CSS は次のように。

section div.bottom:nth-child(1){
   color:#f00;	
}

div 要素をもう一つ大きな要素に内包させる事で nth-child で目的の要素を指定できました。

ここで前の記述を思い出してみると…。

<div class="top">
   トップ1
</div>
<div class="top">
   トップ2
</div>
<div class="bottom">
   ボトム1
</div>
<div class="bottom">
   ボトム2
</div>
div.bottom:nth-child(1){
   color:#f00;
}

これではどれも文字に色が付く事はありませんでした。調べてみると nth-child は class は関係なく div の要素を数えるようです。ようするに、bottom クラスが付いた div 要素の1番目という物は存在しないという事になります。何故なら div 要素の1番目は「トップ1」が書かれた部分だからです。

「div.top:nth-child(1)」で「トップ1」の色が変わった理由は、「.top」を無くしても結局 div の1番目の要素が指定される為です。

外側に section 要素で囲った事で「div.bottom:nth-child(1)」は section 要素の div 要素の1番目という指定になるため色が変わるのです。ただ、「.bottom」のクラス名を無くすと「トップ1」と「ボトム1」の色が変わってしまうのでクラス名も一応意味はあるようです。

  • Pocket

おすすめトピックス

関連記事

リファラーによってiframe内のリンク先をjavascriptで変更する

リファラーによってインラインフレーム内にあるリンクのリンク先を変えれたら便利になるなと思って javascript で自作してみました。こんな事したいと思う人は多分いないニッチなものだと思います。 どういう時に使いたかっ […]

オフィス画像モニタ
CSSのみでhtmlタグの中に文章を挿入する方法があります

ウェブサイトの中で html の編集が出来ない場所に文章を書くなど編集する事は出来ません。一見当たり前の事を言っているだけです。しかし、CSS なら出来てしまうかもしれません。 目次1 htmlの編集が出来ない場所とは2 […]

画像のALT属性に文字を入れる気にならないのは画面に表示されないからだと思う

画像の ALT 属性って知っていますか?ALT 属性とは画像に付加するテキスト情報で、画像について手短に説明したテキストを入力する事が望ましいです。画像が表示されない時に何の画像かわかる為の代替テキストとして、音声読み上 […]

iframe内のjavascriptを無効にする方法

html の iframe(インラインフレーム)とは、一つのページ内に小窓を作ってその内部に別ページや別サイトを表示させるタグです。iframe 内のページは自分で作る事もありますが、他の人が作る事もあります。どういう事 […]

videoタグのmp4動画にもサムネイル画像を表示させるには

ニコニコ動画や Youtube を始め、インターネット上で動画を見たり配信する機会が珍しくない時代となりました。むしろ毎日アップロードされる動画が多すぎて見てもらう為の競争となっていると言っても過言ではありません。 そこ […]

MP3ダウンロード
MP3を1クリックだけでストリーミングせずにダウンロードする方法

私はこのサイトとは別に、効果音や BGM の素材サイトを運営しています。ふとそのサイト名で google 検索をしてみた所、驚くべき光景を目にしました。 ポケットサウンドというのがそのサイト名なのですが、Google の […]

著者について

名前:Azell
作曲したり風景写真撮ったりWeb制作したりする人です。 好きな事を楽しくブログに綴れていけたらと思います。

フォローはこちら

       

       
WordPressでログイン時だけ表示する条件分岐を行うには?

WordPress では色々条件分岐があります。トップページだ

チョコと練乳が濃厚なクッキー「北海道美瑛ミルクサンド」| フェルム・ラ・テール

先日北海道のお土産をいただいてとても美味しかったので紹介したい

「東京百年物語~焼きキャラメル」キャラメルがしっとりケーキの東京土産

東京でお土産店を物色していた時、気になるお土産を見つけました。

横蔵寺
【岐阜県の横蔵寺】紅葉時期の駐車場と写真撮影について

岐阜県揖斐川郡揖斐川町にある横蔵寺は紅葉の名所でありますが、即

千歳市のイタリアンレストラン「アキオカ」でパスタランチ

「アキオカ」は北海道千歳市にある格調高いイタリアンレストランで

→もっと見る