之前我们给大家分享了css3实现3d效果的内容,这篇文章给大家分享一个3d的loading效果的实例,下文有实现效果及代码,感兴趣的朋友可以借鉴参考,接下来我们就详细看看吧。
简要说明
这是一款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实现3d效果有帮助,想要了解更多css3实现3d效果的内容,大家可以关注群英网络其它相关文章。
文本转载自脚本之家
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
长按识别二维码并关注微信
更方便到期提醒、手机管理