マウスアウトした時だけtransitionが効かない症状
以下のように、ボタンの上にカーソルを乗せるとフワッと明るくなり、カーソルをボタンから外す(マウスアウト)とフワッと元の色合いに戻る動きにしたい。
フワッと戻るボタン
上のボタンにカーソルを乗せてね!
でも、なぜかマウスアウトしたときだけ一瞬で元の色合いに戻ってしまう…。
フワッと戻らないボタン
上のボタンにカーソルを乗せてね!
ちょっとした違いのようですが、マウスを乗せたとき・離したときで挙動が違うので「このサイト、なんか違和感が…」と感じる人もいるかもしれません。
ということで、サクッと直しちゃいましょう!
マウスアウト時にtransitionが効かない原因と解決方法
結論からいうとtransitionを:hoverに指定しているのが原因です。
CSS (.css)
.btn {
background-color: #5a4498;
color: white;
display:block;
width: 210px;
line-height: 50px;
text-align: center;
cursor: pointer;
}
.btn:hover {
opacity: .7;
transition: .5s;
}
Check!!
13行目で.btn:hover
に対してtransition: .5s;を指定している。
これだと要素にカーソルを合わせた時だけ.btn:hover
のtransitionが有効になるので、要素からカーソルを外した瞬間にtransitionが無効になり、一瞬で元に戻ってしまうという訳です。
正しい書き方
以下のように.btn
本体にtransitionを指定します。
CSS (.css)
.btn {
background-color: #5a4498;
color: white;
display:block;
width: 210px;
line-height: 50px;
text-align: center;
cursor: pointer;
transition: .5s;
}
.btn:hover {
opacity: .7;
}
Check!!
これが正解!
9行目で.btn
に対してtransition: .5s;を指定している。
これでマウスアウトした時にもフワッと色合いが戻るようになります!