今回のお題は、
メニューバーのインタラクション
<body>
要素に加えるメニューバーは、ul
要素class
属性"menu")<li>
要素に含めた<a>
要素には、data-
グローバル属性<a>
要素にひとつだけclass
属性が与えてあるのは、
<ul class="menu">
<li><a href="#" data-bubble="117">Messages</a></li>
<li><a href="#" data-bubble="4">New Posts</a></li>
<li><a class="gold" href="#" data-bubble="1">Hidden Coins</a></li>
</ul>
このHTMLのコードにつぎの<style>
要素のようにCSSを定めると、border-left
とborder-right
)box-shadow
プロパティにより加えた。なお、text-shadow
プロパティで下方向に明るい影をつけて、
body {
padding: 1em 2em;
font: 100%/1.5 "Helvetica Neue", sans-serif;
color: #eee;
background: #485258;
}
.menu {
display: inline-block;
box-shadow: 0.12em 0.12em 0 rgba(40, 40, 40, 0.2);
list-style-type: none;
padding: 0;
}
.menu li {
float:left;
border-left:0.063em solid #a6c6cd;
border-right:0.063em solid #6ca1ac;
}
.menu a {
display: block;
padding: 0 1em;
line-height: 2.5em;
position:relative;
font-weight: bold;
text-decoration: none;
color: #364652;
background-color: #86B2BB;
text-shadow: 0 0.063em 0 #a6c6cd;
}
data:image/s3,"s3://crabby-images/8e3bd/8e3bd4e727a6358a7f4621f90e5576977320cd0e" alt="図1 インタラクションを加える前のメニューバー 図1 インタラクションを加える前のメニューバー"
メニュー項目にマウスポインタを重ねたとき、:hover
と:active
および:focus
で、
.menu a:hover,
.menu a:active,
.menu a:focus {
color: #eee;
text-shadow: 0.063em 0.063em 0 #547177;
}
data:image/s3,"s3://crabby-images/85b6d/85b6d5a74c57939236eb89f67908dbf612159865" alt="図2 マウスポインタを重ねるとテキストの表現が変わる 図2 マウスポインタを重ねるとテキストの表現が変わる"
body {
padding: 1em 2em;
font: 100%/1.5 "Helvetica Neue", sans-serif;
color: #eee;
background: #485258;
}
.menu {
display: inline-block;
box-shadow: 0.12em 0.12em 0 rgba(40, 40, 40, 0.2);
list-style-type: none;
padding: 0;
}
.menu li {
float:left;
border-left:0.063em solid #a6c6cd;
border-right:0.063em solid #6ca1ac;
}
.menu a {
display: block;
padding: 0 1em;
line-height: 2.5em;
position:relative;
font-weight: bold;
text-decoration: none;
color: #364652;
background-color: #86B2BB;
text-shadow: 0 0.063em 0 #a6c6cd;
}
.menu a:hover,
.menu a:active,
.menu a:focus {
color: #eee;
text-shadow: 0.063em 0.063em 0 #547177;
}
マウスポインタを重ねた項目に数字を示す
つぎは、data-
グローバル属性<a>
要素を属性セレクタ[]
で選んで、::after
擬似要素を加える。表示する数字は、data-
グローバル属性からattr()
式でcontent
プロパティに与えた。border-radius
プロパティで背景の角に丸みをつけ、
.menu a[data-bubble]:after {
content: attr(data-bubble);
position: absolute;
top: 0;
right: 0.5em;
line-height: 1.5em;
padding: 0 0.46em;
text-shadow: 0 0.063em 0 rgba(0, 0, 0, 0.2);
background-color: #eee;
color: #364652;
box-shadow: 0 0.063em 0.063em rgba(0, 0, 0, 0.2);
border-radius: 4em;
}
data:image/s3,"s3://crabby-images/c9d3a/c9d3afb9ae8452ad867ce122771ea9e535353e2d" alt="図3 擬似要素で数字を示す 図3 擬似要素で数字を示す"
擬似要素::after
)z-index
プロパティで、:hover
と:active
および:focus
)top
プロパティで上に持ち上げた
.menu a[data-bubble]::after {
z-index: -1;
transform: translateZ(0);
}
.menu a:hover[data-bubble]::after,
.menu a:active[data-bubble]::after,
.menu a:focus[data-bubble]::after {
top: -1.25em;
z-index: 1;
}
data:image/s3,"s3://crabby-images/ffca4/ffca422d9f7c0945ce61cfe4729ba78194df8c37" alt="図4 マウスポインタを重ねたメニュー項目に数字が示される 図4 マウスポインタを重ねたメニュー項目に数字が示される"
body {
padding: 1em 2em;
font: 100%/1.5 "Helvetica Neue", sans-serif;
color: #eee;
background: #485258;
}
.menu {
display: inline-block;
box-shadow: 0.12em 0.12em 0 rgba(40, 40, 40, 0.2);
list-style-type: none;
padding: 0;
}
.menu li {
float:left;
border-left:0.063em solid #a6c6cd;
border-right:0.063em solid #6ca1ac;
}
.menu a {
display: block;
padding: 0 1em;
line-height: 2.5em;
position:relative;
font-weight: bold;
text-decoration: none;
color: #364652;
background-color: #86B2BB;
text-shadow: 0 0.063em 0 #a6c6cd;
}
.menu a:hover,
.menu a:active,
.menu a:focus {
color: #eee;
text-shadow: 0.063em 0.063em 0 #547177;
}
.menu a[data-bubble]::after {
content: attr(data-bubble);
position: absolute;
top: 0;
right: 0.5em;
line-height: 1.5em;
padding: 0 0.46em;
text-shadow: 0 0.063em 0 rgba(0, 0, 0, 0.2);
background-color: #eee;
color: #364652;
box-shadow: 0 0.063em 0.063em rgba(0, 0, 0, 0.2);
border-radius: 4em;
z-index: -1;
transform: translateZ(0);
}
.menu a:hover[data-bubble]::after,
.menu a:active[data-bubble]::after,
.menu a:focus[data-bubble]::after {
top: -1.25em;
z-index: 1;
}
数字に飛び出すようなアニメーションを加える
いよいよ数字の擬似要素に、animation
プロパティと@keyframes
規則を以下のように加える。これらの定めだけ見ると、transform
プロパティでtranslateY()
関数により、@keyframes
規則をよくよく眺めると、top
プロパティが含まれている。この値は、:hover
と:active
および:focus
) 、animation-fill-mode
プロパティはboth
とした。
キーフレーム | transform | top |
---|---|---|
0% | 0 | 0 |
50% | -12px | - |
100% | 6px | -1. |
.menu a:hover[data-bubble]::after,
.menu a:active[data-bubble]::after,
.menu a:focus[data-bubble]::after {
animation: bubbleover 0.4s;
animation-fill-mode: both;
top: -1.25em;
z-index: 1;
}
@keyframes bubbleover {
0% {
top: 0;
transform: translateY(0);
z-index: -1;
}
50% {
transform: translateY(-12px);
z-index: -1
}
100% {
transform: translateY(6px);
z-index: 1;
}
}
あとおまけとして、class
属性"gold")
<ul class="menu">
<li><a class="gold" href="#" data-bubble="1">Hidden Coins</a></li>
</ul>
a.gold[data-bubble]::after {
background-color: gold;
}
body {
padding: 1em 2em;
font: 100%/1.5 "Helvetica Neue", sans-serif;
color: #eee;
background: #485258;
}
.menu {
display: inline-block;
box-shadow: 0.12em 0.12em 0 rgba(40, 40, 40, 0.2);
list-style-type: none;
padding: 0;
}
.menu li {
float:left;
border-left:0.063em solid #a6c6cd;
border-right:0.063em solid #6ca1ac;
}
.menu a {
display: block;
padding: 0 1em;
line-height: 2.5em;
position:relative;
font-weight: bold;
text-decoration: none;
color: #364652;
background-color: #86B2BB;
text-shadow: 0 0.063em 0 #a6c6cd;
}
.menu a:hover,
.menu a:active,
.menu a:focus {
color: #eee;
text-shadow: 0.063em 0.063em 0 #547177;
}
.menu a[data-bubble]::after {
content: attr(data-bubble);
position: absolute;
top: 0;
right: 0.5em;
line-height: 1.5em;
padding: 0 0.46em;
text-shadow: 0 0.063em 0 rgba(0, 0, 0, 0.2);
background-color: #eee;
color: #364652;
box-shadow: 0 0.063em 0.063em rgba(0, 0, 0, 0.2);
border-radius: 4em;
z-index: -1;
transform: translateZ(0);
}
a.gold[data-bubble]::after {
background-color: gold;
}
.menu a:hover[data-bubble]::after,
.menu a:active[data-bubble]::after,
.menu a:focus[data-bubble]::after {
animation: bubbleover 0.4s;
animation-fill-mode: both;
top: -1.25em;
z-index: 1;
}
@keyframes bubbleover {
0% {
top: 0;
transform: translateY(0);
z-index: -1;
}
50% {
transform: translateY(-12px);
z-index: -1
}
100% {
transform: translateY(6px);
z-index: 1;
}
}