方块上下跳跃跳动加载loading效果
代码语言:html
所属分类:加载滚动
代码描述:方块上下跳跃跳动加载loading效果
下面为部分代码预览,完整代码请点击下载或在bfwstudio webide中打开
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <style> *, *:after, *:before { box-sizing: border-box; } :root { --hue: 185; --radius: 5.5; --size: 4; } body { min-height: 100vh; background: hsl(var(--hue), 20%, 70%); overflow: hidden; margin: 0; padding: 0; } [type='checkbox'] { position: absolute; left: 100%; opacity: 0; height: 0; width: 0; } .scene { -webkit-perspective: 800px; perspective: 800px; -webkit-transform-style: preserve-3d; transform-style: preserve-3d; height: 100vh; width: 100vw; display: -webkit-box; display: flex; -webkit-box-align: center; align-items: center; -webkit-box-pack: center; justify-content: center; } .plane { height: 5vmin; width: 5vmin; -webkit-transform-style: preserve-3d; transform-style: preserve-3d; -webkit-transform: rotateX(-40deg) rotateY(-45deg) rotateX(90deg); transform: rotateX(-40deg) rotateY(-45deg) rotateX(90deg); } .cube, .shadow { --width: var(--size); --height: var(--size); --depth: var(--size); height: calc(var(--depth) * 1vmin); width: calc(var(--width) * 1vmin); -webkit-transform-style: preserve-3d; transform-style: preserve-3d; position: absolute; font-size: 1rem; -webkit-animation: jump 0.8s calc(var(--d) * 1s) infinite; animation: jump 0.8s calc(var(--d) * 1s) infinite; -webkit-transform: translate3d(calc((var(--x) * var(--radius)) * 1vmin), calc((var(--y) * var(--radius)) * -1vmin), 0); transform: translate3d(calc((var(--x) * var(--radius)) * 1vmin), calc((var(--y) * var(--radius)) * -1vmin), 0); } .cube > div:nth-of-type(1), .shadow > div:nth-of-type(1) { background: hsl(var(--hue), 60%, 50%); height: calc(var(--height) * 1vmin); width: 100%; -webkit-transform-origin: 50% 50%; transform-origin: 50% 50%; -webkit-transform: rotateX(-90deg); transform: rotateX(-90deg); position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%, -50%) rotateX(-90deg) translate3d(0, 0, calc((var(--depth) / 2) * 1vmin)); transform: translate(-50%, -50%) rotateX(-90deg) translate3d(0, 0, calc((var(--depth) / 2) * 1vmin)); } .cube > div:nth-of-type(2), .shadow > div:nth-of-type(2) { background: hsl(var(--hue), 60%, 60%); height: calc(var(--height) * 1vmin); width: 100%; -webkit-transform-origin: 50% 50%; transform-origin: 50% 50%; -webkit-transform: translate(-50%, -50%) rotateX(-90deg) rotateY(180deg) translate3d(0, 0, calc((var(--depth) / 2) * 1vmin)); transform: translate(-50%, -50%) rotateX(-90deg) rotateY(180deg) translate3d(0, 0, calc((var(--depth) / 2) * 1vmin)); position: absolute; top: 50%; left: 50%; } .cube > div:nth-of-type(3), .shadow > div:nth-of-type(3) { background: hsl(var(--hue), 60%, 60%); height: calc(var(--height) * 1vmin); width: calc(var(--depth) * 1vmin); -webkit-transform: translate(-50%, -50%) rotateX(-90deg) rotateY(90deg) translate3d(0, 0, calc((var(--width) / 2) * 1vmin)); transform: translate(-50%, -50%) rotateX(-90deg) rotateY(90deg) translate3d(0, 0, calc((var(--width) / 2) * 1vmin)); position: absolute; top: 50%; left: 50%; } .cube > div:nth-of-type(4), .shadow > div:nth-of-type(4) { background: hsl(var(--hue), 60%, 55%); height: calc(var(--height) * 1vmin); width: calc(var(--depth) * 1vmin); -webkit-transform: translate(-50%, -50%) rotateX(-90deg) rotateY(-90deg) translate3d(0, 0, calc((var(--width) / 2) * 1vmin)); transform: translate(-50%, -50%) rotateX(-90deg) rotateY(-90deg) translate3d(0, 0, calc((var(--width) / 2) * 1vmin)); position: absolute; top: 50%; left: 50%; } .cube > div:nth-of-type(5), .shadow > div:nth-of-type(5) { background: hsl(var(--hue), 60%, 45%); height: calc(var(--depth) * 1vmin); width: calc(var(--width) * 1vmin); -webkit-transform: translate(-50%, -50%) translate3d(0, 0, calc((var(--height) / 2) * 1vmin)); transform: translate(-50%, -50%) translate3d(0, 0, calc((var(--height) / 2) * 1vmin)); position: absolute; top: 50%; left: 50%; } .cube > div:nth-of-type(6), .shadow > div:nth-of-type(6) { background: hsl(var(--hue), 60%, 65%); height: calc(var(--depth) * 1vmin); width: calc(var(--width) * 1vmin); -webkit-transform: translate(-50%, -50%) translate3d(0, 0, calc((var(--height) / 2) * -1vmin)) rotateX(180deg); transform: translate(-50%, -50%) translate3d(0, 0, calc((var(--height) / 2) * -1vmin)) rotateX(180deg); position: absolute; top: 50%; left: 50%; } .shadow { -webkit-animation: none; animation: none; background: radial-gradient(#000, transparent); -webkit-transform: translate3d(calc((var(--x) * var(--radius)) * 1vmin), calc((var(--y) * var(--radius)) * -1vmin), calc(var(--size) * -0.5vmin)) scale(1); transform: translate3d(calc((var(--x) * var(--radius)) * 1vmin), calc((var(--y) * var(--radius)) * -1vmin), calc(var(--size) * -0.5vmin)) scale(1); -webkit-animation: shadow 0.8s calc(var(--d) * 1s) infinite; animation: shadow 0.8s calc(var(--d) * 1s) infinite; } .cube--0, .shadow--0 { --x: 1; --y: 0; --d: -0.7; } .cube--1, .shadow--1 { --x: 1; --y: -1; --d: -0.6; } .cube--2, .shadow--2 { --x: 0; --y: -1; --d: -0.5; } .cube--3, .shadow--3 { --x: -1; --y: -1; --d: -0.4; } .cube--4, .shadow--4 { --x: -1; --y: 0; --d: -0.3; } .cube--5, .shadow--5 { --x: -1; --y: 1; --d: -0.2; } .cube--6, .shadow--6 { --x: 0; --y: 1; --d: -0.1; } .cube--7, .shadow--7 { --x: 1; --y: 1; --d: 0; } @-webkit-keyframes jump { 0%, 30%, 100% { -webkit-transform: translate3d(calc((var(--x) * var(--radius)) * 1vmin), calc((var(--y) * var(--radius)) * -1vmin), 0); transform: translate3d(calc((var(--x) * .........完整代码请登录后点击上方下载按钮下载查看
网友评论0