今回のお題は、
メニューのもとになる静的スタイル
まず、<body>
要素に書くコードの構成だ。メニューは、class
属性が"menu"の<ul>
要素でリストとして組み立てる。メニュー項目をclass
属性"item"の<li>
要素とし、<a>
要素にテキストを加えた。そして、<ul>
要素全体を、class
属性"container"の<div>
要素で包んでいる。
<div class="container">
<ul class="menu">
<li class="item"><a href="#">HTML</a></li>
<li class="item"><a href="#">CSS</a></li>
<li class="item"><a href="#">JavaScript</a></li>
<li class="item"><a href="#">XML</a></li>
</ul>
</div>
この<body>
要素の記述に対して、<style>
要素を加える。今のところ、<script>
要素で-prefix-freeを読み込んだ
<script src="lib/prefixfree.min.js"></script>
<style>
body {
font-family: Arial, Helvetica, sans-serif;
background: dimgray;
}
.container {
height: 50px;
margin: 40px 0;
padding: 50px 0;
text-align: center;
}
.menu {
display: inline-block;
list-style: none;
margin: 0;
overflow: hidden;
padding: 0;
position: relative;
background: linear-gradient(ghostwhite, gainsboro);
}
.item {
float: left;
font-size: 14px;
line-height: 50px;
padding: 0 35px;
cursor: pointer;
}
.item a {
color: gray;
display: block;
text-decoration: none;
text-shadow: 0 1px 0 white;
}
</style>
data:image/s3,"s3://crabby-images/b9d1f/b9d1f85954fa86018b5657ae6cdbff1bc730ddbd" alt="図1 メニューのもととなるスタイル 図1 メニューのもととなるスタイル"
メニューの背景色とテキストの影
今回のお題は、<style>
要素の定めでは、class
属性"menu")background
プロパティに、linear-gradient()
関数で線形のグラデーションを加えている。おそらく気づきにくいだろうから、
.menu {
/* background: linear-gradient(ghostwhite, gainsboro); */
background: linear-gradient(white, black);
}
.item a {
text-shadow: 0 1px 0 white;
}
data:image/s3,"s3://crabby-images/b35fb/b35fbba7e23101896ab953e24db658a089743ba0" alt="図2 メニュー背景のグラデーションと項目テキストの影 図2 メニュー背景のグラデーションと項目テキストの影"
もうひとつ気づくのは、text-shadow
プロパティに影の水平・
text-shadow: 水平のずれ 垂直のずれ ぼけ幅 カラー
なお、linear-gradient()
関数の第1引数には、to bottom
)
linear-gradient([to 方向,] 始まりの色, 終わりの色)
メニュー項目の間に区切り線を入れる
メニューバーの項目class
属性"item")border-left
とborder-right
で明暗の差をつければよい。まずは、
.item {
border-left: 4px solid white;
border-right: 4px solid black;
}
data:image/s3,"s3://crabby-images/a1612/a161291eda8239b98caf95c976e1735b23609532" alt="図3 メニュー項目の左右に区切り線が入る 図3 メニュー項目の左右に区切り線が入る"
効果が確かめられたところで、:first-child
と:last-child
で指定してなくすnone
)
.item {
border-left: 1px solid white;
border-right: 1px solid gainsboro;
}
li.item:first-child {
border-left: none;
}
li.item:last-child {
border-right: none;
}
data:image/s3,"s3://crabby-images/8db35/8db358d47ff14cf328197c873827dd0cb38976e1" alt="図4 区切り線により少し膨らんで見えるメニュー項目 図4 区切り線により少し膨らんで見えるメニュー項目"
メニューバーに外枠を加える
メニューを動かす前に、border
プロパティを用いてもよい。けれど、box-shadow
プロパティを活用してみよう。影は普通ぼかす。ぼかさないときは、box-shadow
プロパティには、
box-shadow: [inset] 水平のずれ 垂直のずれ ぼけ幅 [伸縮量] カラー
メニューバーclass
属性"menu")
.menu {
box-shadow: 0 0 0 4px cyan;
}
data:image/s3,"s3://crabby-images/fb761/fb761dda73601bf4b3b8fb2132bf8e1f1e5ec30a" alt="図5 影でメニューバーに太めの外枠が加わる 図5 影でメニューバーに太めの外枠が加わる"
改めて、box-shadow
プロパティを定め直そう。メニューバーに、
.menu {
box-shadow: 0 0 0 1px white;
}
data:image/s3,"s3://crabby-images/6808c/6808cdad56c21ec2521f0b796fc75e97cffa7c13" alt="図6 メニューバーに細い外枠が加わった 図6 メニューバーに細い外枠が加わった"
メニュー項目にポインタが重なったとき他の項目のテキストをぼかす
いよいよ、text-shadow
プロパティで影をつくったうえで、transparent
キーワードで透明にするのだ。メニューバーclass
属性"menu"):hover
擬似クラスで、<a>
要素につぎのような定めを加えた。これで、
.menu:hover a {
color: transparent;
text-shadow: 0 0 5px silver;
}
data:image/s3,"s3://crabby-images/75bed/75bedde312dc9870df04dc6a5f4f4f820b1889f2" alt="図7 マウスポインタをメニューバーに重ねると項目のテキストがぼける 図7 マウスポインタをメニューバーに重ねると項目のテキストがぼける"
ポインタが重なったメニュー項目を浮き上がらせるアニメーション
つぎに、class
属性"item"):hover
擬似クラスで、<a>
要素のテキストは暗くして際立たせる。また、
.item:hover {
background: ghostwhite;
}
.item:hover a {
color: black;
text-shadow: 0 1px 1px white;
}
data:image/s3,"s3://crabby-images/ae6bc/ae6bc589ad9a443d9c6119496db3bd54b0d27d70" alt="図8 マウスポインタを重ねたメニュー項目がハイライトする 図8 マウスポインタを重ねたメニュー項目がハイライトする"
さらに、transform
プロパティにtranslateY()
関数で垂直移動し、scale()
関数の引数に比率を渡す。引数は2つだとそれぞれ水平と垂直、
.item:hover a {
transform: translateY(-2px) scale(1.02);
}
data:image/s3,"s3://crabby-images/36d43/36d4380a0e7aa98e480fa9067a1ff5c66c240dac" alt="図9 マウスポインタを重ねたメニュー項目のテキストが浮かび上がる表現 図9 マウスポインタを重ねたメニュー項目のテキストが浮かび上がる表現"
滑らかなアニメーションにするため、class
属性"item")transition
プロパティを定める。タイミング関数は、ease-in
を選んだtransition
プロパティは継承しないので、<a>
要素にも同じ定めを加えた。
.item {
transition: 0.2s ease-in;
}
.item a {
transition: 0.2s ease-in;
}
data:image/s3,"s3://crabby-images/28cc1/28cc129b45cd6f3bb605928bf88ed02495a0bf97" alt="図10 タイミング関数のease-in 図10 タイミング関数のease-in"
※この図はMozilla Contributorsによるもので、CC-BY-SA 2.
マウスボタンを押したメニュー項目を凹ませる
仕上げは、class
属性"item"):active
擬似クラスに、inset
)transition
プロパティの定めを取り消すことnone
)
.item:active {
border-left-color: whitesmoke;
box-shadow: inset 0 0 22px lightgrey;
transition: none;
}
.item:active a {
color: dimgray;
transform: translateY(-1px);
transition: none;
}
data:image/s3,"s3://crabby-images/6fd06/6fd06782878dca44f7aefcff5eefda8b32f988c3" alt="図11 マウスボタンを押したメニュー項目が凹む表現 図11 マウスボタンを押したメニュー項目が凹む表現"
これで選択項目以外がぼけるメニューのでき上がりだ。書き上げたCSSの定めは、
body {
font-family: Arial, Helvetica, sans-serif;
background: dimgray;
}
.container {
height: 50px;
margin: 40px 0;
padding: 50px 0;
text-align: center;
}
.menu {
display: inline-block;
list-style: none;
margin: 0;
overflow: hidden;
padding: 0;
position: relative;
background: linear-gradient(ghostwhite, gainsboro);
box-shadow: 0 0 0 1px white;
}
.item {
float: left;
border-left: 1px solid white;
border-right: 1px solid gainsboro;
font-size: 14px;
line-height: 50px;
padding: 0 35px;
cursor: pointer;
transition: 0.2s ease-in;
}
.item a {
color: gray;
display: block;
text-decoration: none;
text-shadow: 0 1px 0 white;
transition: 0.2s ease-in;
}
li.item:first-child {
border-left: none;
}
li.item:last-child {
border-right: none;
}
.menu:hover a {
color: transparent;
text-shadow: 0 0 5px silver;
}
.item:hover {
background: ghostwhite;
}
.item:hover a {
color: black;
transform: translateY(-2px) scale(1.02);
text-shadow: 0 1px 1px white;
}
.item:active {
border-left-color: whitesmoke;
box-shadow: inset 0 0 22px lightgrey;
transition: none;
}
.item:active a {
color: dimgray;
transform: translateY(-1px);
transition: none;
}