乐趣区

简单几步,用纯CSS3实现3D翻转效果!

作为前端开发人员的必修课,CSS3 能带我们完成许多基本动效,本期我们将用 CSS3 实现 hover 翻转效果~
第一步非常简单,我们简单画 1 个演示方块,为其添加 transition 和 transform 属性:
// 本示例均使用 Sass 语法
.block {
width: 200px;
height: 200px;
background: brown;
cursor: pointer;
transition: 0.8s;
&:hover {
transform: rotateY(180deg);
}
}
我们看一看这时候的效果:

这里需要注意的是:transition 属性要写在.block 上而不是 hover 上,如果只在 hover 上写 transition,则鼠标移出时并没有 transition 的过渡效果,如果我们只将 transition 写在 hover 上:

第二步比较关键:我们不难发现始终在 1 个平面上翻转,不够有立体感,因此我们需要稍加改变思路——用 2 层 div 嵌套
// html 部分
<div class=”block”>
<div class=”block-in”></div>
</div>
// CSS 部分
.block {
width: 200px;
height: 200px;
cursor: pointer;

&-in {
background: brown;
height: 100%;
transition: 0.8s;
}

&:hover .block-in {
transform: rotateY(180deg);
}
}
此时效果没变,如下:

这个时候关键的 1 步来了:我们需要给外层添加 perspective 和 transform-style 属性,为整个动画增添 3D 变形效果:
.block {
width: 200px;
height: 200px;
cursor: pointer;
/* 3D 变形 */
transform-style: preserve-3d;
-webkit-perspective: 1000;
-moz-perspective: 1000;
-ms-perspective: 1000;
perspective: 1000;

&-in {
background: brown;
height: 100%;
transition: 0.8s;
}

&:hover .block-in {
transform: rotateY(180deg);
}
}
最终实现效果如下:

最终我们总结一下思路:1. 建立内外 2 层 div,鼠标 hover 到外层时,内层 div 添加翻转 transform: rotateY(180deg)2. 注意将 transition 属性添加到需要翻转的 div 上,而不是 hover 时 3. 外层 div 添加 perspective 和 transform-style 属性,最终实现 3D 翻转效果

退出移动版