轉載說明:原創不易,未經授權,謝絕任何形式的轉載
俗話說得好,興趣是最好的老師。本篇文章搜集了幾個漂亮的宇宙風格按鈕動畫效果的代碼,希望它們能夠激發你對 CSS 的熱愛。作為前端開發者,我們不僅僅是制作寫頁面和與 後端 API 打交道,偶爾也需要調味劑。廢話不多說,讓我們一起來解讀這些 CSS 代碼吧。
1、粒子動畫效果的按鈕
HTML部分
<button class="btn" type="button">
<strong>SPACE</strong>
<div id="container-stars">
<div id="stars"></div>
</div>
<div id="glow">
<div class="circle"></div>
<div class="circle"></div>
</div>
</button>
CSS部分
.btn {
display: flex;
justify-content: center;
align-items: center;
width: 13rem;
height: 3rem;
background-size: 300% 300%;
backdrop-filter: blur(1rem);
border-radius: 5rem;
transition: 0.5s;
animation: gradient_301 5s ease infinite;
border: double 4px transparent;
background-image: linear-gradient(#212121, #212121), linear-gradient(137.48deg, #ffdb3b 10%,#FE53BB 45%, #8F51EA 67%, #0044ff 87%);
background-origin: border-box;
background-clip: content-box, border-box;
}
#container-stars {
position: fixed;
z-index: -1;
width: 100%;
height: 100%;
overflow: hidden;
transition: 0.5s;
backdrop-filter: blur(1rem);
border-radius: 5rem;
}
strong {
z-index: 2;
font-family: 'Avalors Personal Use';
font-size: 12px;
letter-spacing: 5px;
color: #FFFFFF;
text-shadow: 0 0 4px white;
}
#glow {
position: absolute;
display: flex;
width: 12rem;
}
.circle {
width: 100%;
height: 30px;
filter: blur(2rem);
animation: pulse_3011 4s infinite;
z-index: -1;
}
.circle:nth-of-type(1) {
background: rgba(254, 83, 186, 0.636);
}
.circle:nth-of-type(2) {
background: rgba(142, 81, 234, 0.704);
}
.btn:hover #container-stars {
z-index: 1;
background-color: #212121;
}
.btn:hover {
transform: scale(1.1)
}
.btn:active {
border: double 4px #FE53BB;
background-origin: border-box;
background-clip: content-box, border-box;
animation: none;
}
.btn:active .circle {
background: #FE53BB;
}
#stars {
position: relative;
background: transparent;
width: 200rem;
height: 200rem;
}
#stars::after {
content: "";
position: absolute;
top: -10rem;
left: -100rem;
width: 100%;
height: 100%;
animation: animStarRotate 90s linear infinite;
}
#stars::after {
background-image: radial-gradient(#ffffff 1px, transparent 1%);
background-size: 50px 50px;
}
#stars::before {
content: "";
position: absolute;
top: 0;
left: -50%;
width: 170%;
height: 500%;
animation: animStar 60s linear infinite;
}
#stars::before {
background-image: radial-gradient(#ffffff 1px, transparent 1%);
background-size: 50px 50px;
opacity: 0.5;
}
@keyframes animStar {
from {
transform: translateY(0);
}
to {
transform: translateY(-135rem);
}
}
@keyframes animStarRotate {
from {
transform: rotate(360deg);
}
to {
transform: rotate(0);
}
}
@keyframes gradient_301 {
0% {
background-position: 0% 50%;
}
50% {
background-position: 100% 50%;
}
100% {
background-position: 0% 50%;
}
}
@keyframes pulse_3011 {
0% {
transform: scale(0.75);
box-shadow: 0 0 0 0 rgba(0, 0, 0, 0.7);
}
70% {
transform: scale(1);
box-shadow: 0 0 0 10px rgba(0, 0, 0, 0);
}
100% {
transform: scale(0.75);
box-shadow: 0 0 0 0 rgba(0, 0, 0, 0);
}
}
代碼解釋
- 按鈕的文字是“SPACE”,使用了strong标簽來加粗字型。
- 按鈕背景是一個漸變色背景,使用了linear-gradient函數來實作。
- 按鈕邊框是一個空心的圓角矩形,使用了border屬性來實作。
- 按鈕内部有一個含有星星動畫效果的div,使用了position:fixed來實作全屏,以及兩個僞元素before和after來生成星星。
- 按鈕内部還有一個發光的圓形動畫效果,使用了兩個.circle元素,以及animation屬性和filter屬性來實作。
- 當滑鼠懸停在按鈕上時,星星背景會出現,并且按鈕會放大。
- 當按鈕被點選時,發光效果變成粉色,并且漸變色背景和星星動畫效果都停止。
@keyframes pulse_3011
這個動畫定義了一個名為“pulse_3011”的關鍵幀動畫。在該動畫中,元素從開始狀态縮小到0.75倍,同時有一個0.7不透明度的黑色陰影。在動畫執行的70%處,元素擴大到原始大小,同時黑色陰影消失。最終,元素再次縮小到0.75倍,而黑色陰影再次消失。該動畫無限重複。
stars::before 和 stars::after 相關的代碼是實作星星循環動畫的關鍵,設定了背景為一個由白色和透明顔色交替組成的徑向漸變色,這樣就形成了一些閃閃發光的小星星。通過 animation 屬性設定了動畫效果,其中 animStar 是一個移動動畫,設定了 60s 的動畫時間,并且使用 linear 動畫函數,使得小星星以勻速向上移動的方式出現在螢幕上,并且使用 infinite 讓其循環播放。這樣就形成了一些往上移動的小星星,進而實作了整個星空的動态效果。
月亮和太陽效果切換的按鈕
HTML部分
<button>
<div id="moon" class="state"> Moony</div>
<div id="sun" class="state">Sunny</div>
<span class="border border1"></span>
<span class="border border2"></span>
</button>
CSS部分
button {
--sunGradient: linear-gradient(to right, #fa709a 0%, #fee140 100%);
--moonGradient: linear-gradient(to right, #6a11cb 0%, #2575fc 100%);
display: flex;
justify-content: center;
align-items: center;
position: relative;
width: 85px;
height: 85px;
color: white;
font-size: 0.8em;
font-weight: bold;
text-transform: uppercase;
border-radius: 70px;
background-color: transparent;
transition: 0.09s;
box-shadow: 0 20px 30px black;
overflow: hidden;
}
button:hover {
transform: rotate(360deg);
}
button:active {
transform: rotate(360deg) scale(1.2);
box-shadow: -15px -15px 500px white,inset 0 0 5px black, 0px -15px 20px white;
}
.state {
position: absolute;
display: flex;
justify-content: center;
align-items: center;
border-radius: inherit;
width: 90%;
height: 90%;
border: 4px groove black;
}
#sun {
display: none;
transition: 2s;
background: var(--sunGradient);
}
#moon {
background: var(--moonGradient);
}
button:hover #sun {
display: flex;
}
button:active #moon {
display: none;
}
.border {
position: absolute;
transition: 0.4s;
z-index: -1;
border-radius: inherit;
background: var(--moonGradient);
}
button:hover .border {
background: var(--sunGradient);
}
.border1 {
width: 45px;
height: 100px;
animation: 1s linear reverse infinite rotation_91;
}
.border2 {
width: 200px;
height: 35px;
animation: 3s linear reverse infinite rotation_91;
}
@keyframes rotation_91 {
from {
transform: rotate(0deg)
}
to {
transform: rotate(360deg)
}
}
代碼解釋:
這段代碼實作了一個狀态切換的動畫按鈕效果,它包含兩個狀态:一個是太陽狀态,另一個是月亮狀态。當滑鼠懸停在按鈕上時,太陽狀态會出現,月亮狀态會消失。當使用者點選按鈕時,按鈕會放大并旋轉,并且太陽狀态會替換成月亮狀态,月亮狀态則替換成太陽狀态。
具體實作的邏輯如下:
HTML部分:
- 一個<button>元素,作為容器來包含按鈕的其他元素。
- 兩個狀态元素:<div id="sun" class="state">和<div id="moon" class="state">,它們分别表示太陽和月亮狀态,并且它們都有一個state類,用于設定它們的共同樣式。
- 兩個邊框元素:<span class="border border1"></span>和<span class="border border2"></span>,它們用于設定按鈕的邊框樣式。
CSS部分:
- 設定按鈕的基本樣式:它是一個圓形的容器,它的背景顔色是透明的。它有一個黑色的描邊,以及一個白色的陰影。
- 當使用者懸停在按鈕上時,它會旋轉360度。
- 當使用者點選按鈕時,它會放大并旋轉360度,并且它的陰影會變成白色的。
- 兩個狀态元素的共同樣式:它們的位置是絕對定位的,它們都是圓形的,它們都有一個4像素的黑色描邊,它們的寬度和高度都是按鈕的90%。
- 太陽狀态元素的樣式:它的背景是一個漸變,當使用者懸停在按鈕上時,它會顯示出來。
- 月亮狀态元素的樣式:它的背景也是一個漸變。
- 當使用者懸停在按鈕上時,它的邊框會變成太陽狀态元素的漸變顔色。
- 兩個邊框元素的樣式:它們的位置是絕對定位的,它們的顔色是按鈕的月亮狀态的漸變顔色,它們分别有兩個不同的大小和不同的動畫,它們都是無限循環的動畫。
- 最後,使用keyframes關鍵字定義兩個動畫rotation_91,使它們旋轉360度。
3、小行星光圈帶環繞
HTML部分
<button>
Button
</button>
CSS部分:
button {
position: relative;
padding: 18px 55px;
font-size: 15px;
font-weight: bold;
color: #fff;
background: linear-gradient(87deg, #6d67e4, #7743db, #4e31aa, #6d67e4, #6d67e4);
background-size: 600% 600%;
border: 3px solid #7743db;
border-radius: 8px;
/* filter: drop-shadow(0 0 4px #9F73AB); */
box-shadow: inset 0 0 10px 1px #7743db, 0 0 10px 5px #7743db;
cursor: pointer;
transition: all 0.5s;
animation: GradientAnimation 25s ease infinite;
}
button::after {
content: "";
position: absolute;
width: 202px;
height: 54px;
top: 0;
left: -17px;
border: 5px solid #453c67;
border-width: 0 2px 4px 0;
border-radius: 100%;
filter: drop-shadow(0px 0px 6px rgba(78, 49, 180, 1));
transform: rotate(-30deg);
animation: LinerAfter 15s ease infinite;
}
button::before {
content: "";
position: absolute;
width: 200px;
height: 50px;
top: 0;
left: -20px;
border: 5px solid #6d67e4;
border-width: 0 12px 8px 4px;
border-radius: 100%;
filter: drop-shadow(0px 0px 6px rgba(109, 103, 228, 1));
/* box-shadow: inset 0 0 10px 1px #4E31AA, 0 0 10px 5px #4E31AA; */
transform: rotate(-30deg);
transition: all 0.5s;
animation: LinerBefore 15s ease infinite;
}
@keyframes GradientAnimation {
0% {
background-position: 0% 50%;
}
50% {
background-position: 100% 50%;
}
100% {
background-position: 0% 50%;
}
}
@keyframes LinerAfter {
0% {
left: -27px;
height: 54px;
}
50% {
left: -7px;
height: 37px;
}
100% {
left: -27px;
height: 54px;
}
}
@keyframes LinerBefore {
0% {
left: -30px;
height: 50px;
}
50% {
left: -10px;
height: 33px;
}
100% {
left: -30px;
height: 50px;
}
}
代碼解釋:
CSS代碼設定了按鈕的樣式,包括位置、内邊距、字型大小、加粗程度、顔色、背景、邊框、圓角、光标形狀、過渡效果、動畫等。其中background屬性使用了線性漸變,border屬性設定了3px寬度的實線邊框,border-radius屬性設定了8px的圓角。box-shadow屬性設定了兩個陰影效果,一個是内陰影,另一個是外陰影。button::after和button::before是button的僞元素,分别表示按鈕前面和後面的圓圈。這兩個圓圈都是絕對定位,大小、位置、邊框、圓角等屬性不同,但都使用了drop-shadow濾鏡和rotate旋轉變換效果。動畫效果分别由GradientAnimation、LinerAfter和LinerBefore三個關鍵幀動畫控制,分别設定了不同的屬性變化規則,實作了按鈕和圓圈的不同的動态效果。
結束
今天的内容就分享到這裡,太多了就不利于我們去了解,雖然就三個案例,但是需要我們去慢慢消化和了解,才能成為自己的知識,建議大家還是親自實作下上述的按鈕動畫效果,這些案例雖然我們在平常的工作中很少用到,但是如果你接到酷炫的項目,比如某品牌的宣傳站點時,我相信這些效果還是能派上用場的。
如果你喜歡這樣的文章,請點贊支援下,後續我會持續分享這類的内容,如果太少,我會覺得大家不太喜歡這樣的文章,我隻能自己私藏了,最後别忘記關注「前端達人」,你的支援将是我分享最大的動力,後續我會持續輸出更多内容,敬請期待。