纯css实现3D翻转效果

705 阅读1分钟

要实现3D翻转效果,可以使用CSS中的transformtransition属性来创建。在这个示例中,我们将为每个图片项添加3D翻转效果,触发方式为鼠标悬停。

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>3D翻转效果</title>
    <style>
        body {
            display: flex;
            justify-content: center;
            align-items: center;
            height: 100vh;
            margin: 0;
            background-color: #f5f5f5;
            font-family: Arial, sans-serif;
        }

        .gallery {
            display: flex;
            perspective: 1000px;
        }

        .photo {
            width: 200px;
            height: 300px;
            margin: 0 10px;
            transition: transform 0.6s;
            transform-style: preserve-3d;
            position: relative;
        }

        .photo:hover {
            transform: rotateY(180deg);
        }

        .photo img {
            width: 100%;
            height: 100%;
            backface-visibility: hidden;
            position: absolute;
            top: 0;
            left: 0;
            object-fit: cover;
            border-radius: 10px;
        }

        .photo img.back {
            transform: rotateY(180deg);
        }
    </style>
</head>
<body>
    <div class="gallery">
        <div class="photo">
            <img src="https://picsum.photos/200/100?random=1" alt="Front">
            <img src="https://picsum.photos/200/100?random=2" alt="Back" class="back">
        </div>
        <div class="photo">
            <img src="https://picsum.photos/200/100?random=3" alt="Front">
            <img src="https://picsum.photos/200/100?random=4" alt="Back" class="back">
        </div>
        <div class="photo">
            <img src="https://picsum.photos/200/100?random=5" alt="Front">
            <img src="https://picsum.photos/200/100?random=6" alt="Back" class="back">
        </div>
    </div>
</body>
</html>

说明

  1. 容器设置

    • 使用perspective创建3D视角效果。
  2. 翻转效果

    • 使用transform-style: preserve-3d保持3D效果。
    • 悬停时,通过rotateY(180deg)来实现3D翻转。
  3. 图片设置

    • 前后图片通过backface-visibilityposition: absolute叠加显示,正面图片默认显示,背面则旋转180度。

可以根据需要调整每张照片的大小和旋转速度。