css3用transform实现正方体效果
要使用CSS3的transform
属性实现正方体效果,你需要创建6个面(正面、背面、上面、下面、左面、右面),并应用不同的旋转效果。以下是实现正方体的基本HTML和CSS代码示例:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<style>
.cube {
width: 100px;
height: 100px;
margin: 50px;
position: relative;
transform-style: preserve-3d;
animation: rotate 5s infinite linear;
}
.face {
position: absolute;
width: 100%;
height: 100%;
background: #f0f0f0;
border: 1px solid #000;
}
.front {
transform: translateZ(50px);
}
.back {
transform: rotateY(180deg) translateZ(50px);
}
.right {
transform: rotateY(90deg) translateZ(50px);
}
.left {
transform: rotateY(-90deg) translateZ(50px);
}
.top {
transform: rotateX(90deg) translateZ(50px);
}
.bottom {
transform: rotateX(-90deg) translateZ(50px);
}
@keyframes rotate {
0% {
transform: rotateX(0deg) rotateY(0deg);
}
100% {
transform: rotateX(360deg) rotateY(360deg);
}
}
</style>
</head>
<body>
<div class="cube">
<div class="face front"></div>
<div class="face back"></div>
<div class="face right"></div>
<div class="face left"></div>
<div class="face top"></div>
<div class="face bottom"></div>
</div>
</body>
</html>
在这个例子中,.cube
是包含所有面的容器,它使用 transform-style: preserve-3d;
来确保子元素在3D空间中呈现。每个 .face
代表一个正方体的面,通过不同的 transform
属性值来定位它们。动画 @keyframes rotate
使正方体持续旋转。
评论已关闭