亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用純CSS實現拋盒子的loader

發布時間:2022-02-28 15:35:49 來源:億速云 閱讀:161 作者:小新 欄目:web開發

小編給大家分享一下怎么用純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”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

css
AI

邢台县| 钟祥市| 拜城县| 诸暨市| 岱山县| 五指山市| 平谷区| 攀枝花市| 赞皇县| 耒阳市| 安康市| 崇仁县| 桑植县| 康定县| 大荔县| 崇义县| 蒲城县| 资阳市| 洛浦县| 石阡县| 秦安县| 林周县| 宝鸡市| 墨脱县| 北海市| 砀山县| 宝应县| 商洛市| 江西省| 宣化县| 浠水县| 娄烦县| 三门峡市| 遂昌县| 山阳县| 永泰县| 青浦区| 周至县| 和静县| 青冈县| 广汉市|