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

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

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

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

hover

これは、HTMLの 擬似クラス[hover]に関するタグです。Hoverは与えられた要素へマウスカーソルを置くことを意味します。また、タッチ可能なデバイスでユーザーが要素へタッチすることをHoverと呼ぶ場合もあります。

CSS

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

Q&A

解決済

1回答

1450閲覧

transitionを付けたらhoverが効かなくなりました

2235813816

総合スコア5

CSS3

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

hover

これは、HTMLの 擬似クラス[hover]に関するタグです。Hoverは与えられた要素へマウスカーソルを置くことを意味します。また、タッチ可能なデバイスでユーザーが要素へタッチすることをHoverと呼ぶ場合もあります。

CSS

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

0グッド

0クリップ

投稿2020/03/08 09:44

編集2020/03/08 10:59

前提・実現したいこと

CSSで、メニューの項目にマウスホバーをしたら背景色が変わるようにしたいです。

発生している問題・エラーメッセージ

メニューをアコーディオンメニューにしてトランジションを設定したらhoverが効かなくなりました。
それまでは効いていたのでトランジションのどこかの記述がhoverを打ち消しているのだと思うのですがわかりません。
初心者です。途方に暮れています。

該当のソースコード

HTML

<nav class="menu"> <label for="menu_bar01">▼メニュー▼</label> <input type="checkbox" id="menu_bar01" class="accordion" /> <ul id="links01"> <li><a href="#">はじめに</a></li> <li><a href="#">1</a></li> <li><a href="#">2</a></li> <li><a href="#">3</a></li> <li><a href="#">4</a></li> <li><a href="#">5</a></li> <li><a href="#">6</a></li> <li><a href="#">7</a></li> <li><a href="#">8</a></li> <li><a href="#">9</a></li> <li><a href="#">10</a></li> </ul> </nav>

CSS

.menu {
max-width: 600px; }

input {
display: none; }

label {
display: block;
font-size: 28px;
font-weight: 600;
color: #000;
margin: 0 0 4px 0;
padding : 15px;
line-height: 1;
background : #F9E562;
cursor :pointer;
border: 4px solid #AF7912; }

.menu ul {
width: 100%;
list-style: none;
margin: 0;
padding: 0; }

.menu li {
height: 0;
overflow: hidden;
-webkit-transition: all 0.5s;
-moz-transition: all 0.5s;
-ms-transition: all 0.5s;
-o-transition: all 0.5s;
transition: all 0.5s; }

.menu ul li a {
display: block;
padding: 2%;
font-size: 24px;
font-weight: 700;
text-decoration: none;
background: #fff;
color: #222;
text-align: center;
margin: 10;
border: 3px solid #000; }

.menu ul li a:hover {

   background: #888; }

試したこと

hoverの効かない場合について色々調べたり記述の順番を変えたりしましたが一向に効きません。
ご指摘をいただいて空白を詰めたのですが駄目でした。

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

ツールはBracketsを使っています。

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

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

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

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

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

hwatarig

2020/03/08 11:21

「hoverが効かなくなりました」というのは、マウスオーバー時に「.menu ul li a」の背景色が変わらない、ということでしょうか?質問文に記載されているコードでは再現しませんでした。問題なく背景色が#888に変わります。 https://codepen.io/w1103h/pen/OJVOaKr liの高さを0に設定している点から見て、本来のコードではJavaScriptでメニューの開閉を設定されていると思います。関係あるかわかりませんが念の為そちらのコードも質問文に記載いただけますか? また、コードを記載する際はhtml、css、Javascriptごとに分けてコードブロックを利用いただけると見やすいです。
2235813816

2020/03/08 11:28

はい。背景色が変わらないということです。 Javascript?のことはまだよくわからず、おそらく使用していません。
guest

回答1

0

ベストアンサー

htmlがない上、CSSを見る限りでも不思議な点がいくつかあるのでこれだけで直るかはわかりませんが、少なくとも、a:hoverはこのようにスペースを入れずに書かないと効きませんよ。可能であればhtmlも載せてください。

css

1.menu ul li a:hover { 2 background: #888; 3}

追記
コメントを受けて。
以下のようにhoverは効いています。(liの高さを変更して見えるようにしてあります。)
hover

投稿2020/03/08 10:04

編集2020/03/08 11:31
soliste16

総合スコア757

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

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

2235813816

2020/03/08 11:00

HTMLを載せました。すみませんでした。 ご指摘ありがとうございます。空白を詰めてみましたがまだ効かないようです。
soliste16

2020/03/08 11:31 編集

行いたいことが分かりかねます。 字詰めしたことにより<li>内の<a>タグにはhoverがきちんと効いています。それとも他の部分にhoverを効かせたいのでしょうか。
2235813816

2020/03/08 11:36

すみません、確認し直したら効きました! プレビューの更新が遅れていただけのようです。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問