- 话不多说,直接上代码了。
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
body{
background: black;
}
.box_3D{
perspective: 1500px;
}
.box{
width: 200px;
height: 200px;
margin: 300px auto;
position: relative;
transform-style: preserve-3d;
animation: xuanzhuan 10s infinite linear;
}
@keyframes xuanzhuan {
0%{
transform:rotateX(-13deg) rotateY(0deg);
}
100%{
transform:rotateX(-13deg) rotateY(180deg);
}
}
.box>div{
width: 100%;
height: 100%;
box-shadow: 0 0 10px #b100ff;
position: absolute;
top: 0;
left: 0;
color: chartreuse;
text-align: center;
line-height: 200px;
}
</style>
</head>
<body>
<div class="box_3D">
<div class="box">
</div>
</div>
<script>
var box = document.querySelector(".box");
var boxChild = box.children;
var arrImg = ["ban1.jpg","ban2.jpg","ban3.jpg","ban4.jpg","ban5.jpg","ban6.jpg","ban1.jpg","ban2.jpg","ban3.jpg","ban4.jpg","ban5.jpg","ban6.jpg"];
for (let i=0;i<12;i++){
box.innerHTML += "<div></div>" ;
boxChild[i].style.transform = "rotateY("+ 30*i +"deg) translateZ(400px)";
boxChild[i].style.backgroundImage = "url("+ arrImg[i] +")";
}
</script>
</body>
</html>
- 最终效果如下: