简要说明
这是一款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特效的资料请关注脚本之家其它相关文章!
qq空间有欢迎动画,想要给网页制作一个开场动画效果,该怎么制作呢?下面我们就...
演示图如下: HTML代码片段: !DOCTYPE HTMLhtml head title404/title meta char...
对任何网站来说,颜色都是最重要的元素之一,对观众有着巨大的影响,因而对颜色...
1.今年情人节不收礼,收礼只收男朋友。 2.爱错了人,每天都是愚人节;爱对了人...
浏览器引擎前缀(Vendor Prefix)是什么? Vendor prefix浏览器引擎前缀,是一些放...
简介: 方升架构作为新一代云服务器架构的典范,是阿里云云原生基础设施的最佳实...
XPath是一种用来从文档树中选择节点和节点集的语言。从XPath的角度来看,共有七...
首先提示,处于安全的需要JavaScript不能直接访问本地资源文件,那怎么办呢?下...
Dreamweaver制作网页的时候,一般有提交数据的表单制作,有时需要在表单中添加跳...
一. 引入外部css文件的基本样式 用 link标签引入外部样式表,其中通常要写两个属...