您好,登錄后才能下訂單哦!
小編給大家分享一下怎么用純CSS實現拋盒子的loader,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
代碼解讀
定義dom,只有1個元素:
<divclass="loader"></div>
居中顯示:
body{
margin:0;
height:100vh;
display:flex;
align-items:center;
justify-content:center;
background-color:teal;
}
畫出一根木條:
.loader{
width:6em;
border-bottom:0.25emsolidwhite;
font-size:30px;
border-radius:0.125em;
}
用偽元素在其上畫出一個盒子:
.loader{
position:relative;
}
.loader::before{
content:'';
position:absolute;
width:1em;
height:1em;
border:0.25emsolidwhite;
bottom:0;
left:0.5em;
border-radius:0.25em;
}
讓圖案傾斜,形成盒子在坡上的效果:
.loader{
transform:rotate(-45deg);
left:1em;
top:1em;
}
接下來制作動畫。
讓盒子一步步爬坡,爬到坡頂再重爬:
.loader::before{
animation:push4sinfinite;
}
@keyframespush{
0%{
transform:translateX(0);
}
20%,25%{
transform:translateX(1em);
}
40%,45%{
transform:translateX(2em);
}
60%,65%{
transform:translateX(3em);
}
80%{
transform:translateX(0);
}
}
增加盒子在爬坡的過程中的滾動效果:
@keyframespush{
0%{
transform:translateX(0)rotate(0deg);
}
20%,25%{
transform:translateX(1em)rotate(calc(90deg*1));
}
40%,45%{
transform:translateX(2em)rotate(calc(90deg*2));
}
60%,65%{
transform:translateX(3em)rotate(calc(90deg*3));
}
80%{
transform:translateX(0)rotate(0deg);
}
}
增加盒子在爬坡過程中的擬人效果:
@keyframespush{
0%{
transform:translateX(0)rotate(0deg);
}
5%{
transform:translateX(0)rotate(-5deg);
}
20%,25%{
transform:translateX(1em)rotate(calc(90deg*1+5deg));
}
30%{
transform:translateX(1em)rotate(calc(90deg*1-5deg));
}
40%,45%{
transform:translateX(2em)rotate(calc(90deg*2+5deg));
}
50%{
transform:translateX(2em)rotate(calc(90deg*2-5deg));
}
60%,65%{
transform:translateX(3em)rotate(calc(90deg*3+5deg));
}
70%{
transform:translateX(3em)rotate(calc(90deg*3-5deg));
}
80%{
transform:translateX(0)rotate(-5deg);
}
}
讓木條在箱子爬到接近頂點時做拋擲動作:
.loader{
animation:throw3sinfinite;
transform-origin:20%;
}
@keyframesthrow{
0%,70%,100%{
transform:rotate(-45deg);
}
80%{
transform:rotate(-135deg);
}
}
增加盒子在爬到接近頂點時的掉落效果:
@keyframespush{
70%{
transform:translateX(3em)translateY(0)rotate(calc(90deg*3-5deg))scale(1);
filter:opacity(1);
}
80%{
transform:translateX(0)translateY(-5em)rotate(-5deg)scale(0);
filter:opacity(0.5);
}
90%{
transform:translateX(0)translateY(0)rotate(0deg)scale(0);
}
}
最后,隱藏掉可能超出頁面的部分:
body{
overflow:hidden;
}
以上是“怎么用純CSS實現拋盒子的loader”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。