*

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

おすすめトピックス

関連記事

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

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

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

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

リストの表示数を制限する
HTMLでulタグのリスト項目の表示数を制限する

HTML で ul タグを使えば以下のようなリストを作れます。 リスト リスト リスト このようなやつですね。順序なしリストと呼ばれて、何かを箇条書する時に便利です。html タグでは以下のように記述します。 この箇条書 […]

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

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

縦の三点リーダー
縦の三点リーダーをウェブサイト上で表示する方法

三点リーダーという言葉をご存知でしょうか。日本語の世界では度々登場するもので、小説、雑誌、文書など様々な場面に登場するものです。三点リーダーとはすなわち「…」、点が3つ並んだものです。普段のメールなどの会話でも言葉を省略 […]

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

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

著者について

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

フォローはこちら

       

       
彦根市の緑豊かで温かい雰囲気の民家カフェ「MokuMoku」でランチ

滋賀県彦根市にある隠れ家的民家カフェ「MokuMoku(モクモ

世界一のジェラート
彦根市にある世界一のジェラート店「ジェラテリアアズーロ」で滋賀ならではの味を堪能

世界一のジェラートのお店が滋賀県に、彦根市にあるなんて。半信半

スマホで遊園地経営ゲーム「ローラーコースタータイクーンタッチ」レビュー

自分で夢のワンダーランドを作る遊園地経営シミュレーションゲーム

大垣で和風生パスタ!半個室で落ち着くニーニャニーニョ桜小町

岐阜県大垣市にニーニャニーニョ桜小町というパスタ店がありました

滋賀県の高校野球予選を観戦するのに入場料金はいくら?

夏、7月。全国の高校球児達が甲子園を目指して熾烈な野球の戦いが

→もっと見る