CSS3制作3D立方体loading特效
程序员文章站
2022-03-14 21:20:58
简要说明这是一款css3炫酷3d立方体预加载loading特效。该特效通过简单的html元素和css3代码,构建几个立方体不停运动的动画特效,适用于做页面的loading效果。代码解析在html文件中...
简要说明
这是一款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特效的资料请关注其它相关文章!