今回も引き続き、
テキストの上を水平線が横切る
前回の<body>
要素に書いたコードに、<div>
要素class
属性"item")<a>
要素class
属性"link")data-
グローバル属性が与えられた空の<span>
要素を2つ添えた。そして、<a>
要素にはアニメーションのためのclass
属性
<div class="container">
<div class="item">
<a class="link animation-2" href="http://gihyo.jp/design/serial/01/away3d-typescript">
Away3D
<span data-letters="Away3D"></span>
<span data-letters="Away3D"></span>
</a>
</div>
</div>
このアニメーションのclass
属性
.animation-2 {
font-weight: 800;
color: Steelblue;
font-family: 'Dosis', sans-serif;
line-height: 1.3em;
margin-top: -0.2em;
}
<a>
要素に加えたテキストの静的なスタイルdata:image/s3,"s3://crabby-images/dc8a9/dc8a939386ba215e8825f972fbb9ab432c3cdfee" alt="図1 <a>要素に加えたテキストの静的なスタイル 図1 <a>要素に加えたテキストの静的なスタイル"
はじめに加える擬似要素は、transform
プロパティに与えたtranslateX()
関数でテキストの左に移した
.animation-2::before {
content: '';
width: 100%;
height: 6px;
background: white;
position: absolute;
top: 50%;
transform: translateX(-100%);
}
data:image/s3,"s3://crabby-images/7cbe0/7cbe01013325ffe91ae2a39b2e1cd1dbd0e849ff" alt="図2 ::before擬似要素でテキストの左に加えた水平線 図2 ::before擬似要素でテキストの左に加えた水平線"
その水平線は、:hover
擬似クラス)、transition
とtransform
プロパティ)。なお、animation-2
)overflow
プロパティにhidden
を与えて、
.animation-2 {
overflow: hidden;
}
.animation-2::before {
transition: 0.4s ease-in-out;
}
.animation-2:hover::before {
transform: translateX(100%);
}
.animation-2 {
font-weight: 800;
color: Steelblue;
font-family: 'Dosis', sans-serif;
overflow: hidden;
line-height: 1.3em;
margin-top: -0.2em;
}
.animation-2::before {
content: '';
width: 100%;
height: 6px;
background: white;
position: absolute;
top: 50%;
transform: translateX(-100%);
transition: 0.4s ease-in-out;
}
.animation-2:hover::before {
transform: translateX(100%);
}
擬似要素でつくった2つのテキストを重ねる
つぎに、class
属性"animation-2")<span>
要素にも、data-
グローバル属性からattr()
式で得た同じテキストを異なる色で定めた
<a class="link animation-2" href="http://gihyo.jp/design/serial/01/away3d-typescript">
Away3D
<span data-letters="Away3D"></span>
<span data-letters="Away3D"></span>
</a>
.animation-2 span::before {
content: attr(data-letters);
color: white;
}
data:image/s3,"s3://crabby-images/02f54/02f54f5dba6f9b415c0a2f3fa7041dfe1c2118b5" alt="図3 擬似要素で加えられた2つのテキスト 図3 擬似要素で加えられた2つのテキスト"
そのうえで、
.animation-2 span {
position: absolute;
left: 0;
}
.animation-2 span::before {
position: absolute;
}
data:image/s3,"s3://crabby-images/659df/659df5541d38a1c6d740ac3a735561f5039a73c5" alt="図4 2つの擬似要素のテキストがもとのテキストに重なった 図4 2つの擬似要素のテキストがもとのテキストに重なった"
.animation-2 {
font-weight: 800;
color: Steelblue;
font-family: 'Dosis', sans-serif;
overflow: hidden;
line-height: 1.3em;
margin-top: -0.2em;
}
.animation-2::before {
content: '';
width: 100%;
height: 6px;
background: white;
position: absolute;
top: 50%;
transform: translateX(-100%);
transition: 0.4s ease-in-out;
}
.animation-2:hover::before {
transform: translateX(100%);
}
.animation-2 span {
position: absolute;
left: 0;
}
.animation-2 span::before {
content: attr(data-letters);
position: absolute;
color: white;
}
擬似要素のテキストを垂直にアニメーションさせる
擬似要素でテキストを2つ加えたのは、
.animation-2 span {
height: 50%;
width: 100%;
overflow: hidden;
}
data:image/s3,"s3://crabby-images/d53e5/d53e51312dc41e2835dfdbebea66609fdda20671" alt="図5 擬似要素のテキストの上半分だけが表れた 図5 擬似要素のテキストの上半分だけが表れた"
そしてつぎのように、transition-timing-function
は、transition
にも定められるタイミング関数を設定するease
だ。
.animation-2 span::before {
transition: 0.5s;
transform: translateY(100%);
}
.animation-2:hover span::before {
transform: translateY(0);
transition-timing-function: ease-out;
}
data:image/s3,"s3://crabby-images/704c6/704c68f83910a63783308d379402150ee418a0b1" alt="図6 マウスポインタを重ねると垂直方向中央から上に向かってテキストが表れる 図6 マウスポインタを重ねると垂直方向中央から上に向かってテキストが表れる"
タイミング関数のease-in
の値の変化は、
data:image/s3,"s3://crabby-images/6e520/6e52061566bd250fc06039d9633fcbd408157080" alt="図7 タイミング関数のease-out 図7 タイミング関数のease-out"
2つ目の擬似要素で下半分のテキストアニメーションを加える
前項では、<span>
要素は、:first-child
と:last-child
で切り分ければよい
.animation-2 span::before {
/* transform: translateY(100%); */
}
.animation-2 span:first-child::before {
transform: translateY(100%);
}
下半分は、<span>
要素の位置top
プロパティ)
.animation-2 span:last-child {
top: 50%;
}
.animation-2 span:last-child::before {
bottom: 0;
transform: translateY(-100%);
}
data:image/s3,"s3://crabby-images/27af0/27af03033a27492009a132e5384a49f5d35adbb9" alt="図8 マウスポインタを重ねると2つの擬似要素のテキストが垂直方向真ん中から上下に広がるように表れる 図8 マウスポインタを重ねると2つの擬似要素のテキストが垂直方向真ん中から上下に広がるように表れる"
仕上げに、class
属性"animation-2")transition
プロパティを定めた。2つめの秒数値は、none
に切り替え、color
プロパティを透明transparent
)
.animation-2 {
transition: 0.5s 0.25s;
}
.animation-2:hover {
transition: none;
color: transparent;
}
これで、<body>
要素に加えたHTMLコードは、
.animation-2 {
font-weight: 800;
color: Steelblue;
font-family: 'Dosis', sans-serif;
transition: 0.5s 0.25s;
overflow: hidden;
line-height: 1.3em;
margin-top: -0.2em;
}
.animation-2:hover {
transition: none;
color: transparent;
}
.animation-2::before {
content: '';
width: 100%;
height: 6px;
background: white;
position: absolute;
top: 50%;
transform: translateX(-100%);
transition: 0.4s ease-in-out;
}
.animation-2:hover::before {
transform: translateX(100%);
}
.animation-2 span {
position: absolute;
height: 50%;
width: 100%;
left: 0;
overflow: hidden;
}
.animation-2 span::before {
content: attr(data-letters);
position: absolute;
color: white;
transition: 0.5s;
}
.animation-2 span:last-child {
top: 50%;
}
.animation-2 span:first-child::before {
transform: translateY(100%);
}
.animation-2 span:last-child::before {
bottom: 0;
transform: translateY(-100%);
}
.animation-2:hover span::before {
transform: translateY(0);
transition-timing-function: ease-out;
}
サンプル1 CSS3:Text styles and hover effects