今回のお題は、
メニューのもとになる静的スタイル
まず、<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/187c6/187c6238c175107bc1ddfb1683fb9b0ebb32c8f9" 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/07812/0781295eec844f04291bec6729b04bde92289d55" 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/fd3d2/fd3d27f16b16f874d47a5ed984437b5c1bdbfc85" 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/61f41/61f4128f6068d524ab85480c59feffc4bb58f888" 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/22d6f/22d6fa326c36fe353f6e7bf9ff07cbcba0572daf" alt="図5 影でメニューバーに太めの外枠が加わる 図5 影でメニューバーに太めの外枠が加わる"
改めて、box-shadow
プロパティを定め直そう。メニューバーに、
.menu {
box-shadow: 0 0 0 1px white;
}
data:image/s3,"s3://crabby-images/f0f78/f0f7818f7f073d7e29d451633ca785fd9b8c8f53" 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/d3537/d3537707d3b40d08fdcc29050987373d03522c7b" 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/d1e82/d1e829cc36834c3542ec2c4babc171c45e15cb32" alt="図8 マウスポインタを重ねたメニュー項目がハイライトする 図8 マウスポインタを重ねたメニュー項目がハイライトする"
さらに、transform
プロパティにtranslateY()
関数で垂直移動し、scale()
関数の引数に比率を渡す。引数は2つだとそれぞれ水平と垂直、
.item:hover a {
transform: translateY(-2px) scale(1.02);
}
data:image/s3,"s3://crabby-images/57870/578709e7cc435cde5ea842648a0c316ec23e08f6" 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/1dd5d/1dd5de073575c38c75ea55c0fa2c0b1874d3c93f" 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/da637/da637fc3eb92097a340c594ba7f012085314cab8" 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;
}