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

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

ただいまの
回答率

90.00%

focusで一部の背景色を変えたいが、ページ全体の色が変わってしまう

受付中

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 123

mpamppamtpad

score 0

前提・実現したいこと

初心者です。勉強始めたばかりです。
https://www.youtube.com/watch?v=-tg8BlCv7Uk
この動画でCSSの疑似要素を勉強していました。
focusで選択した部分の色だけを変えたいです。

発生している問題

focusで選択したところの色を変えようとしたのですが、ページ全体の色が変わってしまいました。

該当のソースコード

<!doctype html>
<html>
 <head>
     <meta charset="UTF-8">
     <title>属性セレクタの練習</title>
     <link rel="stylesheet" href="2-6 style.css">
  </head>
 <body>
     <div class="main">
        <h1>Heading 1</h1>
        <a href="#a">mainクラスの子要素のリンク</a>
        <p>
            Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
        </p>
        <input type="text">
        <h2>Heading 2</h2>
        <p>
            Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur.<a href="#b">mainクラスの子要素ではないリンク</a> Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
        </p>
        <a href="#a">mainクラスの子要素のリンク</a>
        <h2>Heading 2</h2>
        <p>
            Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. <a href="#c">mainクラスの子要素ではないリンク</a> Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
        </p>
        <p>
            Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
        </p>
    </div>
    </body>
</html>
body{
    font:1.1em/1.5sans-serif;
    padding-top:20px;
}
.main{
    border:1px solid;
    margin:auto;
    padding:10px 20px 20px;
    width:760px;
}

/* 疑似要素を使うと */
a:link{
    color:crimson;}
a:visited{
    color:green;
}
a:hover{
    text-decoration:none;
    background-color: lightgray;
}
:focus{
    background-color: yellow;
}

試したこと

ファイルをグーグルクロームで開くとうまくいきました。しかし、インターネットエクスプローラーだとページ全体の色が変わってしまいました。

補足情報(FW/ツールのバージョンなど)

windows7でやってます。

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 1

+2

(手元にIEの環境がないため推測になってしまうのですが...)
擬似クラスは基本的に特定の要素に対して設定するもののため、
質問者様が他のセレクタで書いているように 要素:擬似クラス の形で指定するのが一般的かと思います

↓の指定を a:focus に変更したり、逆に正常に動いている擬似クラスを :visited などの形に変更してIEやChromeでの動作を確認すれば、
何が原因で意図しない動作になってしまっているのか、問題の切り分けができそうに思えますが、いかがでしょうか?

:focus{
    background-color: yellow;
}

参考
https://developer.mozilla.org/ja/docs/Web/CSS/Pseudo-classes

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2019/09/16 19:44 編集

    ご回答ありがとうございます。
    回答をいただいたことを試した結果、指定をなしでやると、全体が自動的にフォーカスされてしまうのが原因なのかなと思ったのですが、もしそれが原因ならそれを直す方法はあるのでしょうか?
    それかコードの打ち間違え等、他の原因は考えられるでしょうか?ご回答いただければ幸いです。

    以下、回答いただいたことを試してみた結果どのようになったかの説明です。

    先ずは、指定を a:focus にしてみました。すると、aの場所で、フォーカスした部分の背景色を変えることができました。(IEとChromeともに)
    参考動画では、 input の部分もフォーカスで背景色が変わるようにしていたので、a,input:focus にしてみました。すると、inputの場所は、フォーカスすると背景色が変わるようになりましたが、aの場所はフォーカスせずとも常時背景色が変わったままになってしまいました。(IEとChromeともに)

    次に、正常に動いてるモノの指定を外してみました。:linkと:visitは指定を外しても変化はありませんでした。
    ただ、:hoverの指定を外した後(focusは a:focusで指定してある)、ファイルを開いてマウスカーソルを当てるとページ全体(inputのテキスト部分は除く)の背景色が変化してしましました。inputのテキスト部分にカーソルを当てるとそこの背景色も変化しました。link部分に充てると背景色はページ全体が変わっているのでわかりませんが、Linkの下線は消えました。(IEとChromeともに。ただChromeの場合は、マウスカーソルをページの外に出すと背景色は元に戻る。しかし、IEは一度背景色が変わると、マウスカーソルを移動しても背景色は戻らない)
    focusの指定を外して、hoverの指定を外した場合。
    IEの時は、ページ全体がfocus指定の背景色になり、マウスカーソルを置いたところがhover指定の背景色になりました。また、フォーカスをするとフォーカスをした部分がfocus指定の背景色になり、他の部分はhover指定の背景色になりました。
    Chromeでは、ページを開いてマウスカーソルを当てると、ページ全体が、hover指定の背景色になり、そしてフォーカスをすると、その部分だけがfocus指定の背景色になりました。他の部分はhover指定の背景色だけでした。

    キャンセル

  • 2019/09/16 19:56

    細かく調査されていていいですね!

    私もブラウザごとの詳細な仕様は理解できておらずはっきりとした回答ができませんが、
    特にhtml、cssはブラウザのバージョンや端末の種類によって細かな動作が異なる場合が多々ありますので、
    実現したい挙動を実装することに集中し、あまり深追いはしない方がよいかもしれません...

    > a,input:focus にしてみました。

    こちらは、 `a:focus, input:focus` のように記載すると、意図した記述になるものと思います
    質問者様の書き方も構文上間違いではないですが、それだと `全てのaタグと、フォーカスされたinputタグ` という意味合いになるはずです

    キャンセル

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

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