CSS3制作3D立方體loading特效
發(fā)布時間:2020-11-09 16:13:23 作者:螞蟻開源社區(qū)
我要評論

這篇文章主要介紹了CSS3制作3D立方體loading特效的示例,幫助大家更好的理解和使用CSS3特效,美化自身網頁,感興趣的朋友可以了解下
簡要說明
這是一款css3炫酷3D立方體預加載loading特效。該特效通過簡單的HTML元素和CSS3代碼,構建幾個立方體不停運動的動畫特效,適用于做頁面的loading效果。
代碼解析
在HTML文件中引入下面的文件。
<link rel="stylesheet" type="text/css" href="css/bootstrap-grid.min.css" />
HTML結構
<div class="demo" style="min-height:350px;"> <div class="container"> <div class="row"> <div class="col-md-12"> <div class="loader"> <div class="box"> <div></div> <div></div> <div></div> <div></div> </div> <div class="box"> <div></div> <div></div> <div></div> <div></div> </div> <div class="box"> <div></div> <div></div> <div></div> <div></div> </div> <div class="box"> <div></div> <div></div> <div></div> <div></div> </div> </div> </div> </div> </div> </div>
css樣式
.loader{ --size: 32px; --duration: 800ms; width: 96px; height: 64px; margin: 50px auto; transform-style: preserve-3d; transform-origin: 50% 50%; transform: rotateX(60deg) rotateZ(45deg) rotateY(0deg) translateZ(0px); position: relative; } .loader .box{ width: 32px; height: 32px; transform-style: preserve-3d; position: absolute; top: 0; left: 0; } .loader .box:nth-child(1){ transform: translate(100%, 0); animation: box1 800ms linear infinite; } .loader .box:nth-child(2){ transform: translate(0, 100%); animation: box2 800ms linear infinite; } .loader .box:nth-child(3){ transform: translate(100%, 100%); animation: box3 800ms linear infinite; } .loader .box:nth-child(4){ transform: translate(200%, 0); animation: box4 800ms linear infinite; } .loader .box > div{ --translateZ: calc(var(--size) / 2); --rotateY: 0deg; --rotateX: 0deg; background: #5c8df6; width: 100%; height: 100%; transform: rotateY(var(--rotateY)) rotateX(var(--rotateX)) translateZ(var(--translateZ)); position: absolute; top: auto; right: auto; bottom: auto; left: auto; } .loader .box > div:nth-child(1){ top: 0; left: 0; } .loader .box > div:nth-child(2){ background: #145af2; right: 0; --rotateY: 90deg; } .loader .box > div:nth-child(3){ background: #447cf5; --rotateX: -90deg; } .loader .box > div:nth-child(4){ background: #dbe3f4; top: 0; left: 0; --translateZ: calc(var(--size) * 3 * -1); } @keyframes box1{ 0%, 50%{ transform: translate(100%, 0); } 100%{ transform: translate(200%, 0); } } @keyframes box2{ 0%{ transform: translate(0, 100%); } 50%{ transform: translate(0, 0); } 100%{ transform: translate(100%, 0); } } @keyframes box3{ 0%, 50%{ transform: translate(100%, 100%); } 100%{ transform: translate(0, 100%); } } @keyframes box4{ 0%{ transform: translate(200%, 0); } 50%{ transform: translate(200%, 100%); } 100%{ transform: translate(100%, 100%); } }
以上就是CSS3制作3D立方體loading特效的詳細內容,更多關于CSS3 loading特效的資料請關注腳本之家其它相關文章!
相關文章
- 這篇文章主要介紹了10種CSS3實現的loading動畫,幫助大家更好的美化自身網頁,完成需求,感興趣的朋友可以了解下2020-11-16
- css3 keyframes制作創(chuàng)意有趣的進度條漸變加載動畫,loading進度條動畫特效,非常不錯,喜歡的朋友快來下載吧2020-10-21
- 這篇文章主要介紹了CSS loading效果之 吃豆人的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習2019-09-09
使用css實現android系統(tǒng)的loading加載動畫
這篇文章主要介紹了使用css實現android系統(tǒng)的loading加載動畫,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-07-25- 這篇文章主要介紹了CSS 實現各種 Loading 效果附帶解析過程,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-02-19