cssだけでホバー時にバルーンポップアップを表示させる
javascript
を使わず、css
だけでマウスホバー時に、バルーンポップアップを表示させる方法を紹介します。
完成形は以下のようなイメージです。
最初に完成形のcssを記載します。
.s{
/*リンクテキストのスタイルです*/
color: red;
text-decoration: none;
position: relative;
}
.s-balloon {
/*バルーンのスタイルです*/
/*表示位置を指定します*/
position: absolute;
top: -30px;
left: -15px;
/*非表示にしておきます*/
display: none;
opacity: 0;
/*表示スタイルを指定します*/
padding: 5px;
border-radius: 5px;
color: white;
background-color: blue;
/*影をつけて見栄えを良くします*/
box-shadow: 0px 1px 2px 0px rgba(0, 0, 0, 0.5),
inset 0 1px 0 rgba(255, 255, 255, 0.8),
inset 1px 0 0 rgba(255, 255, 255, 0.3),
inset -1px 0 0 rgba(255, 255, 255, 0.3),
inset 0 -1px 0 rgba(255, 255, 255, 0.2);
/*アニメーションを指定します*/
animation-duration: 0.3s;
animation-name: show-balloon;
}
.s:hover .s-balloon {
/*マウスホバー時のバルーンのスタイルです*/
/*表示するようにします*/
display: inline-block;
opacity: 1;
top: -40px;
}
.s-balloon::before {
/*吹き出し部分の三角形を表示します*/
content: "";
position: absolute;
top: 97%;
left: 20px;
border: 6px solid transparent;
border-top: 6px solid blue;
}
@keyframes show-balloon {
/*アニメーションを定義します*/
0% {
display: none;
opacity: 0;
top: -30px;
}
1% {
display: inline-block;
opacity: 0;
top: -30px;
}
100% {
display: inline-block;
opacity: 1;
top: -40px;
}
}
擬似クラス:hover
css
はjavascript
と違い、イベントを定義できませんが、擬似クラスという機能が用意されています。
例えば、リンクテキストの色を青色にする場合は
a{
color: blue;
}
としますが、リンクテキストにマウスホバーした時は、文字色を赤にしたい場合があります。その場合は以下のようにします。
a{
color: blue;
}
a:hover{
color: red;
}
a:hover
とすると、a
要素がマウスホバーしたときのみこのスタイルが有効になります。
サンプル
以下のようにhtmlを定義し、
<a class="sample1">ここにマウスを重ねてみてください<span class="sample1-balloon">バルーンポップアップを表示します</span></a>
css
を以下のように定義します。
sample1-balloon
クラスはtop
やleft
などを使用して、表示位置を調整しておき、display:none;
で非表示にします。
.sample1{
color: black;
text-decoration: none;
position: relative;
}
.sample1-balloon {
position: absolute;
top: -40px;
left: -15px;
display: none;
padding: 5px;
color: white;
background-color: blue;
}
.sample1:hover .sample1-balloon {
display: inline-block;
}
完成形
あとはスタイルやアニメーションを使用して、見栄えを良くすれば完成です。
吹き出し部分の三角形を表示させる方法についてはcssで三角形を表示する方法で紹介しています。アニメーションについては別の機会に説明したいと思います。