前言
网上有很多关于画面翻转的教程,现在转载一篇个人认为比较好的做法
HTML代码
实现正反面效果的HTML代码,估计你想到该是这样的
|
|
正如你所想,有两个容器,分别存放卡片‘前面’和‘后面’,通过css,我们会指定这两个容器元素自己的这样。注意ontouchstart
这段js,能让你使用触屏来触发翻转动作,显然应该将这段代码单独提取,让javaScript代码放到一起
css代码
|
|
原理
- 在
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样式能帮到你
|
|
使用javascript给容器元素添加这个css flip
类就能触发卡片翻转,不需要用户系统鼠标在上面
|
|
资料:3d翻转效果