CSSでこんな実装ができるとは! 美しい光がきらり✨とボーダーに沿って回転するボタン -Button Shimmer Tricks
Post on:2023年5月15日
ぱっと見は普通の角丸ボタン、CSSグラーデションで実装された美しい光がきらりとボーダーに沿って回転するボタンを実装したデモを紹介します。
小さなボタンですが、CSSコンテナクエリをはじめ、CSSによるマスク、hsl()
の美しいグラデーション、繊細なbox-shadow
とCSSのさまざまなテクニックが駆使されています。
data:image/s3,"s3://crabby-images/b8b9f/b8b9fd34dc94fc35c76b6a747320fe289dbd88ca" alt="美しい光がきらりとボーダーに沿って回転するボタン"
このきらめきを伴ったボタンは、グラデーションを回転させながら要素を左右に移動させて実装されています。この動きに必要なのがボタンのサイズで、このサイズにCSSのコンテナクエリが使用されています。
1 2 3 4 5 6 7 8 |
button{ container-type: size; } @keyframes slide { to { transform: translate(calc(100cqw - 100%), 0); } } |
CSSコンテナクエリについて詳しくは、下記をご覧ください。
実装の仕組みをもうすこし詳しく見てみましょう。
まずは、素のボタン。
data:image/s3,"s3://crabby-images/aaedb/aaedb58f1f86d404426318b1c037c7ee13b545d0" alt="デモのキャプチャ"
素のボタン
ボタンのHTMLは、button
要素にspan
できらめきが実装されています。
1 2 3 4 5 6 7 8 9 |
<button> <span class="spark__container"> <span class="spark"></span> </span> <span class="backdrop"></span> <span class="text"> Shim Shimmer </span> </button> |
.spark
のspan
要素できらめきを作成し、ボタンに沿ってアニメーションさせます。
data:image/s3,"s3://crabby-images/a5d01/a5d01483f347158dd2ec57dc0d41d0038a1ce2ae" alt="デモのキャプチャ"
span
要素できらめきを作成
あとは、形状にあわせてマスクします。
data:image/s3,"s3://crabby-images/b69ea/b69ea8e8f29a6d498bcee56eb56d7b56dcca7260" alt="デモのキャプチャ"
ボタンの形状にマスク
.spark
のCSSは、下記の通り。
1 2 3 4 5 6 7 8 9 |
.spark { position: absolute; inset: 0; border-radius: 100px; rotate: 0deg; overflow: hidden; mask: linear-gradient(white, transparent 50%); animation: flip calc(var(--spark) * 2) infinite steps(2, end); } |
実際の動作は、デモページをご覧ください。
See the Pen
Button Shimmer Tricks ✨ by Jhey (@jh3y)
on CodePen.
上部のプルダウンできらめきを変更できます。
data:image/s3,"s3://crabby-images/698c6/698c62bad17e8440c98aba6c6f74e9dc9ee5cf2c" alt="デモのキャプチャ"
元ネタは下記ツイートから。
CSS Tip ✨
Button shimmers are a cool use case for container queries 🤓
Shift an element side to side whilst spinning a gradient
Don't know the size? Use a query ⚡️
button{container-type: size;}
@ keyframes slide {to{
translate: calc(100cqw-100%) 0;
}}@CodePen link below 👇 pic.twitter.com/OUBqtRpO9D— jhey 🔨🐻✨ (@jh3yy) May 10, 2023
sponsors