纯CSS 实现旋转的骰子
效果图
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>旋转的骰子</title>
<style>
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
transform: perspective(1000px);
{#transform-style: preserve-3d;#}
}
.box ul {
transform-style: preserve-3d;
animation: go 12s linear infinite backwards;
{#transform: rotateY(45deg) rotateX(45deg) rotateZ(45deg);#}
}
ul, li {
list-style: none;
width: 100%;
height: 100%;
position: absolute;
top: 0;
left: 0;
text-align: center;
line-height: 200px;
font-size: 70px;
}
.box {
width: 200px;
height: 200px;
position: relative;
margin: 200px auto;
transform-style: preserve-3d;
}
ul li {
color: #ffffff;
border-radius: 30px;
font-weight: 700;
}
ul li:nth-child(1) {
transform: rotate3d(0, 0, 0, 0deg) translateZ(100px);
background-color: rgba(255, 0, 0, 0.8);
}
ul li:nth-child(2) {
transform: rotateY(-90deg) translateZ(-100px);
background-color: rgba(0, 255, 0, 0.8);
}
ul li:nth-child(3) {
transform: rotate3d(0, 0, 0, 0deg) translateZ(-100px);
background-color: rgba(0, 0, 255, 0.8);
}
ul li:nth-child(4) {
transform: rotateY(90deg) translateZ(-100px);
background-color: rgba(123, 13, 123, 0.8);
}
ul li:nth-child(5) {
transform: rotateX(-90deg) translateZ(100px);
background-color: rgba(23, 130, 225, 0.8);
}
ul li:nth-child(6) {
transform: rotateX(-90deg) translateZ(-100px);
background-color: rgba(252, 0, 123, 0.8);
}
@keyframes go {
0% {
transform: rotateX(0deg) rotateY(0deg) rotateZ(0deg);
}
100% {
transform: rotateX(720deg) rotateY(720deg) rotateZ(720deg);
}
}
</style>
</head>
<body>
<div class="box">
<ul>
<li>1</li>
<li>2</li>
<li>3</li>
<li>4</li>
<li>5</li>
<li>6</li>
</ul>
</div>
</body>
</html>