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

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

新規登録して質問してみよう
ただいま回答率
85.48%
HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

2回答

538閲覧

HTML&CSSの背景色の表示について

Nicks11

総合スコア5

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/07/13 14:24

編集2020/07/13 15:13

HTML&CSSの勉強をしています。
HTMLのulの部分のみ背景をbackground-colorで色を指定し、only-childを用いて実現したいのですが、ページ全体の色が変化してしまいます。どのようにすれば、ulの部分のみ、色を変えることができるのでしょうか。初歩的な質問ですがよろしくお願いいたします。

##HTMLのコード

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>疑似要素の練習</title> <link rel="stylesheet" href="style1.css"> </head> <body> <ul> <li>The first child of ul.</li> <li>2nd child</li> <li>3rd child</li> <li>4th child</li> <li>The last child.</li> </ul> <br> </body> </html>

##CSSのコード

body{ padding: 1% 25%; font-family: sans-serif; } ul{ margin: 25px auto 0; padding: 12px; border: 2px dotted gray; list-style-position: inside; font-size: 1.5em; } li{ margin: 0; padding: 15px; border-bottom: 2px solid #224a6b; } li:last-child{ border-bottom: none; } :only-child{ background-color: tomato; }

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kei344

2020/07/13 14:48

(質問文は編集できます)質問文のHTML/CSSはそれぞれコードブロックで囲んでいただけませんか? ```(バッククオート3つ)で囲み、前後に改行をいれるか、コードを選択して「<code>」ボタンを押すとコードブロックになります。
Nicks11

2020/07/13 15:14

申し訳ございません。変更いたしました!
Daregada

2020/07/13 16:40

ulにだけ色を付けるなら、普通は直接そう(ul { background-color: ...})書けばいいので、「なぜ only-child を使おうと考えたのか」を説明されるといいかと思います。
Nicks11

2020/07/13 16:59

初心者なのでonly-childの使い方、実装の仕様を知ろうと思い、この質問をさせていただいています。only-childは兄弟要素がないものを指定できると僕は解釈したのですが、狙った結果が得られなかったため、質問させていただいています。
Daregada

2020/07/13 17:06

すでにほかの方が説明されているように、html要素(文書全体)に only-child による背景色が付いているので、ul を兄弟要素のない状態にして only-child による背景色が付く状態にしても、単にページを眺めているだけそれを確認できません。開発者ツールなどを使用して確認する必要があります。
guest

回答2

0

仕様を確認すると以下の様に記述されています。

兄弟要素がない要素を表します

今回の場合兄弟要素にあたるものが下記のコードでわかる様存在しているのが原因かと思います。

HTML

1<li>2nd child</li> 2<li>3rd child</li> 3<li>4th child</li> 4<li>The last child.</li>

上記の部分を削ったとき<li>The first child of ul.</li>兄弟要素は存在しないのでbackground-colorが指定されるかと思います。


兄弟要素がある中で一番初めの要素をということでしたら:first-child:last-child または :nth-child(1):nth-last-child(1)を使用するといいと思います。

投稿2020/07/13 14:55

編集2020/07/13 14:56
kai0310

総合スコア2070

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Nicks11

2020/07/13 15:20 編集

only-childはulには適応されないということでしょうか?<li>The first child of ul</li>のみを指定したいわけではないのですが、その場合はどうしたらよいのでしょうか?質問がわかりづらく、申し訳ございません。
kai0310

2020/07/13 15:27

単純にul全てに背景色をつけたいのであるのであれば下記で良いかと。 ul{ background-color: tomato; }
Nicks11

2020/07/13 17:01

only-childの使い方が知りたかったため、この質問をさせていただいています。わかりにくくて、申し訳ございません!
guest

0

ベストアンサー

:only-childは特に指定しない場合<html>要素にも効きます。
提示のコードの場合<br>要素もあるので<ul>要素には効きません。

【初心者向け!Chromeの検証機能(デベロッパーツール)の使い方】
https://saruwakakun.com/html-css/basic/chrome-dev-tool

【ChromeデベロッパーツールでCSSをチェックする方法 | なんでものびるWEB】
https://nandemo-nobiru.com/2944/

投稿2020/07/13 15:25

kei344

総合スコア69400

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Nicks11

2020/07/13 16:57

<br>を消しても表示結果に変化がでませんでした。。。
kei344

2020/07/13 17:01

htmlに背景色が付いているのだから当然変化を目で見るのはできないでしょう。デベロッパーツールで確認してください。(提示されたコードで<br>を消し多状態でulに作用していることは確認済みです)
kei344

2020/07/13 17:12

動画製作者に聞いて下さい。
Nicks11

2020/07/13 17:12

私のPCはWindowsだからそういった変化が起きてしまっているのでしょうか。
Nicks11

2020/07/13 17:14

確認をとってみます。お時間、お手数おかけしてしまい、申し訳ございませんでした。ありがとうございました!
kei344

2020/07/13 17:16

> 私のPCはWindows こちらもWindows Firefox/Chrome で確認済みです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問