vivian blog

画面翻转

前言

网上有很多关于画面翻转的教程,现在转载一篇个人认为比较好的做法

HTML代码

实现正反面效果的HTML代码,估计你想到该是这样的

1
2
3
4
5
6
7
8
9
10
<div class="flip-container" ontouchstart="this.classList.toggle('hover');">
<div class="flipper">
<div class="front">
<!-- 前面内容 -->
</div>
<div class="back">
<!-- 背面内容 -->
</div>
</div>
</div>

正如你所想,有两个容器,分别存放卡片‘前面’和‘后面’,通过css,我们会指定这两个容器元素自己的这样。注意ontouchstart这段js,能让你使用触屏来触发翻转动作,显然应该将这段代码单独提取,让javaScript代码放到一起

css代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
/* 翻转动画 */
.flip-container{
-webkit-perspective: 1000;
perspective: 1000;/*透视属性*/
}
.flip-container:hover .flipper, .flip-container.hover .flipper{
transform: rotateY(180deg);
}
.flip-container, .front, .back{
width: 95px;
height: 95px;
}
/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;
position: relative;
}
/* hide back of pane during swap */
.front,.back{
backface-visibility: hidden;/* 背面可视性 */
position: absolute;
top: 0;
left: 0;
border-radius: 50%;
background: #eee;
display: flex;
justify-content: center;
align-items: center;
}
/* placed above back */
.front {
z-index: 2;
box-shadow: 8px 10px 10px -9px rgba(0,0,0,0.4);
}
/* back, initially hidden pane */
.back {
transform: rotateY(180deg);
box-shadow: -8px 10px 10px -9px rgba(0,0,0,0.4);
}

原理

  • flip-container容器元素上设置整个动画区域的透视perspective属性
  • flip-container元素遇到鼠标悬停事件时,flipper旋转180deg,这里是控制旋转速度的地方,若旋转值设为-180deg,逆方向旋转
  • 表示卡片正反面的元素都要绝对定位,这样他们才能在相同的位置相互遮挡,他们的背面可视性backface-visibility设置为隐藏,这样每个卡片的背面在翻转时都看不见的
  • 将卡片的正面设置为比一个背面要高的z-index的值,保证卡片的正面在最上面
  • 将背面卡片旋转180deg,这样能让她扮演背面的角色

Ana Tudor’s quote

对卡片元素的某些属性设置一些特定的值(例如)(like overflow: hidden)会导致其子元素丧失3D变换功能。我认可他的观点,因为正是在本文的例子中我正好遇到了overflow: hidden相关的麻烦,它导致了3D变换子元素全都出现在了同一个平面上,有几个是被旋转了180度。

触发css翻转

若你喜欢用javaScript来触发翻转动作,下面这个简单的css样式能帮到你

1
2
3
.flip-container:hover .flipper, .flip-container.hover .flipper, .flip-container.flip .flipper {
transform: rotateY(180deg);
}

使用javascript给容器元素添加这个css flip类就能触发卡片翻转,不需要用户系统鼠标在上面

1
document.querySelector("#myCard").classList.toggle("flip");

资料:3d翻转效果