質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.46%

  • HTML5

    5301questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • CSS3

    2705questions

    CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

この「nth-child 」の指定結果が理解できません

解決済

回答 2

投稿

  • 評価
  • クリップ 2
  • VIEW 1,838

megu9859

score 8

下記チュートリアルの「2. テーブルの背景色を交互に変える方法」について、奇数行の指定がなぜこうなるのかが理解できません。
リンク内容

理解できないCSSがここです。
tr:nth-child(odd) {
background: #31A9EE;    /* 奇数行の背景色を指定する */

と言いますのも前述のテーブルの場合、<table>タグの1番目の要素に、<caption>タグを噛ませているためです。
別の例ですが下図のように、「nth-child 」は「nth-of-type」と違って、該当タグのtrだけではなく並列する要素のすべてが対象に含まれるはず。
イメージ説明

そしてoddは奇数番目なので、まずは下記に絞られるはずです。
1番目の要素. <caption>テーブルタイトル</caption>
3番目の要素. 「1行目 (左の列)」から始まる<tr>タグ
5番目の要素. 「3行目 (左の列)」から始まる<tr>タグ
7番目の要素. 「5行目 (左の列)」から始まる<tr>タグ
‥‥
さらにここから、<tr>タグだけに絞られるので、実際に青背景色のCSSが当たるのは、
3番目の要素. 「1行目 (左の列)」から始まる<tr>タグ
5番目の要素. 「3行目 (左の列)」から始まる<tr>タグ
7番目の要素. 「5行目 (左の列)」から始まる<tr>タグ
‥‥
になると想定します。

しかし、実際の検証結果はこのようになっております。
イメージ説明

なぜ親要素から数えて、同じく奇数番目の要素である<caption>タグが無視されるのでしょう?

これが「nth-of-type」での指定なら理解できるのですが‥‥
前述のチュートリアルだけではなく、所持している参考書でも同様の結果となっていたので、混乱しております。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • mts10806

    2019/04/17 13:18

    「回答がつかなかったりついたのに放置したまま次の質問を次々と立てるのは良くない」と指摘しているだけで、「何時間以内に解決してね」とは思っていません。
    回答者観点から「解決する気ないな」となればアドバイスは得られにくくなるのは当然ですし、回答を得られずに困るのは質問者さんですよね。
    この手(未解決質問放置質問)の指摘は私に限らずよく指摘は行われてますよ。

    キャンセル

  • mts10806

    2019/04/17 13:32

    追記されたんですかね。
    ブロック機能は今のところありませんので。

    キャンセル

  • megu9859

    2019/04/17 19:27

    ありがとうございます。承知いたしました。

    キャンセル

回答 2

checkベストアンサー

+10

<table>の中に直接<tr>を書いても、HTMLの処理としては<table>の下に<tbody>があって、その中に<tr>があるものと解釈されます。一方で、<caption><table>直下に置かれます。

そのため、tr:nth-child(odd)に、<tr>と兄弟要素とならない<caption>は数えられません。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/04/20 15:16

    ご回答いただきまして誠にありがとうございます。自動的に<tbody>が挿入されることを初めて知り、「そういうことだったんだ」と納得がいきました。
    ※ご連絡が遅れまして申し訳ございません。

    キャンセル

+5

なぜtable直下にtr要素を許可しているのに勝手にtbodyが入るのか?
その疑問はわかります。
歴史的な経緯を言うと、HTML4 時代は tbody 要素は省略不可で、table 直下に直接 tr が来ることはありませんでした。タグを書かなくても tbody 要素が存在する状態です。
そのため、HTML5 が普及した今日でも主要ブラウザはとりあえずタグがなくとも tbody を補ってしまうようです。

勝手に補わないよう、XHTML 形式で認識させるとどうなるか?
ちゃんと思い通りになります。
イメージ説明

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/04/20 15:18

    ご回答いただきまして誠にありがとうございます。これまでの背景を知ることで、ますます理解を深めることができました。そのうえ、表作成までしていただき、心から感謝したいです。
    ※ご連絡が遅れまして申し訳ございません。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.46%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • HTML5

    5301questions

    HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

  • CSS3

    2705questions

    CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。