CSS图片翻转动画技术详解(IE也实现了)


Posted in HTML / CSS onApril 03, 2014

CSS动画非常的有趣;这种技术的美就在于,通过使用很多简单的属性,你能创建出就连皮克斯动画制作公司也会赞叹的漂亮的消隐效果。其中代表性的一种就是CSS图片翻转效果,能让你看到一张卡片的正反两面上的内容。本文就是要用最简单的方法向大家介绍如何创建这种效果。

简单说明:这并不是第一篇我介绍这种技术的文章,但我发现那些都过于复杂了。网上还有很多其它的教材,但里面添加了很多多余的代码样式,需要读者去分清哪些是必要的,那些是无用的;本文避免了这些问题,只列出了必要的CSS代码,你可以在其上添加自己喜欢的风格来美化这些卡片。

HTML代码

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

复制代码
代码如下:

<div class="flip-container lazy " ontouchstart="this.classList.toggle('hover');">
<div class="flipper lazy ">
<div class="front lazy ">
<!-- 前面内容 -->
</div>
<div class="back lazy ">
<!-- 背面内容 -->
</div>
</div>
</div>

正如你想到的,应该有两个容器,分别存放卡片“前面”和“背面”,通过CSS,我们会指定这两个容器元素自己的作用。还有需要注意的是ontouchstart这段js,它能让你使用触屏来触发翻转动作。显然,你应该把这段代码单独提取出来,让JavaScript代码放到一起。

CSS代码

我敢打赌,你会感到惊讶,只需要如此少的代码(如果不考虑各浏览器CSS方言前缀):

复制代码
代码如下:

/* entire container, keeps perspective */
.flip-container {
perspective: 1000;
}
/* flip the pane when hovered */
.flip-container:hover .flipper, .flip-container.hover .flipper {
transform: rotateY(180deg);
}</p> <p>.flip-container, .front, .back {
width: 320px;
height: 480px;
}</p> <p>/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;</p> <p> position: relative;
}</p> <p>/* hide back of pane during swap */
.front, .back {
backface-visibility: hidden;</p> <p> position: absolute;
top: 0;
left: 0;
}</p> <p>/* front pane, placed above back */
.front {
z-index: 2;
}</p> <p>/* back, initially hidden pane */
.back {
transform: rotateY(180deg);
}

下面是大概的整个过程的原理:
1.在最外层的容器元素上设置整个动画区域的透视(perspective)属性。
2.当外层容器元素遇到鼠标悬停事件时,内部存放卡片的容器旋转180度。这里也是控制旋转速度的地方。如果将旋转值设置为-180deg,是反向旋转。
3.表示卡片正面和背面的元素都要绝对定位,这样它们才能在相同的位置相互遮挡。它们的背面可视性(backface-visibility)属性设置为隐藏,这样每个卡片的背面在翻转时都是看不见的。
4.将卡片的正面设置为一个比背面要高的z-index值,这样保证卡片的正面在最上面。
5.将背面卡片旋转180度,这样让它扮演背面的角色。
6.这就是全部这些代码的作用!你把这段代码放到你的网页里,然后修饰一下卡片的样式就行了!

来自CSS动画专家Ana Tudor的提示

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

触发CSS翻转

如果你喜欢用JavaScript来触发翻转动作,下面这个简单的css样式类就能帮你做到这样:

复制代码
代码如下:

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

使用javascript给容器元素添加这个cssflip类就能触发卡片翻转——不需要用户悬停鼠标在上面。用document.querySelector("#myCard").classList.toggle("flip")实现它!

CSS竖向翻转

执行竖向翻转也很简单,跟横向翻转一样,只需要修改一下 transform-origin的值,然后让它按X轴旋转。

复制代码
代码如下:

.vertical.flip-container {
position: relative;
}</p> <p> .vertical .back {
transform: rotateX(180deg);
}</p> <p> .vertical.flip-container .flipper {
transform-origin: 100% 213.5px; /* 高的一半 */
}</p> <p> .vertical.flip-container:hover .flipper {
transform: rotateX(-180deg);
}

注意这里用的是rotateX,而不是之前的rotateY。

让IE支持这种动画技术

需要针对IE对这段标准的卡片翻转代码进行特殊的修改,因为IE还没有实现现代浏览器中的transform功能。基本的做法就是对正面和背面两个卡片同时分别翻转:

复制代码
代码如下:

/* entire container, keeps perspective */
.flip-container {
perspective: 1000;
transform-style: preserve-3d;
}
/* UPDATED! flip the pane when hovered */
.flip-container:hover .back {
transform: rotateY(0deg);
}
.flip-container:hover .front {
transform: rotateY(180deg);
}</p> <p>.flip-container, .front, .back {
width: 320px;
height: 480px;
}</p> <p>/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;</p> <p> position: relative;
}</p> <p>/* hide back of pane during swap */
.front, .back {
backface-visibility: hidden;
transition: 0.6s;
transform-style: preserve-3d;</p> <p> position: absolute;
top: 0;
left: 0;
}</p> <p>/* UPDATED! front pane, placed above back */
.front {
z-index: 2;
transform: rotateY(0deg);
}</p> <p>/* back, initially hidden pane */
.back {
transform: rotateY(-180deg);
}</p> <p>/*
Some vertical flip updates
*/
.vertical.flip-container {
position: relative;
}</p> <p> .vertical .back {
transform: rotateX(180deg);
}</p> <p> .vertical.flip-container:hover .back {
transform: rotateX(0deg);
}</p> <p> .vertical.flip-container:hover .front {
transform: rotateX(180deg);
}

使用上面的这段代码,IE10里也能正确的进行卡片翻转了!

这个CSS卡片翻转动画技术一直是一个经典的案例,代表着CSS动画能够实现的效果,甚至3DCSS动画能实现的强大效果。优点就是使用的代码很少很简单。对于制作HTML5动画来说这种效果非常的实用,可以说完美。你还能想到其它用到这个效果的地方吗?

HTML / CSS 相关文章推荐
CSS3解决移动页面上点击链接触发色块的问题
Jun 03 HTML / CSS
css3发光搜索表单分享
Apr 11 HTML / CSS
css3 实现滚动条美化效果的实例代码
Jan 06 HTML / CSS
HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影
Mar 07 HTML / CSS
Application Cache未缓存文件无法访问无法加载问题
May 31 HTML / CSS
HTML5 虚拟键盘出现挡住输入框的解决办法
Feb 14 HTML / CSS
canvas进阶之如何画出平滑的曲线
Oct 15 HTML / CSS
手把手教你实现一个canvas智绘画板的方法
Mar 04 HTML / CSS
利用 Canvas实现绘画一个未闭合的带进度条的圆环
Jul 26 HTML / CSS
HTML5页面无缝闪开的问题及解决方案
Jun 11 HTML / CSS
详解CSS中的特指度和层叠问题
Jul 15 HTML / CSS
VW、VH适配移动端的解决方案与常见问题
May 21 HTML / CSS
使用CSS媒体查询(Media Queries)和JavaScript判断浏览器设备类型的方法
Apr 03 #HTML / CSS
css3实现input输入框颜色渐变发光效果代码
Apr 02 #HTML / CSS
CSS去掉A标签(链接)虚线框的方法
Apr 01 #HTML / CSS
使用css3背景渐变中的透明度来设置不同颜色的背景渐变
Mar 31 #HTML / CSS
你应该知道的30个css选择器
Mar 19 #HTML / CSS
纯CSS3打造动感漂亮时尚的扇形菜单
Mar 18 #HTML / CSS
CSS3中background-clip和background-origin的区别示例介绍
Mar 10 #HTML / CSS
You might like
在php中使用sockets:从新闻组中获取文章
2006/10/09 PHP
解决中英文字符串长度问题函数
2007/01/16 PHP
ThinkPHP模板比较标签用法详解
2014/06/30 PHP
Symfony2实现在controller中获取url的方法
2016/03/18 PHP
通过jquery还原含有rowspan、colspan的table的实现方法
2012/02/10 Javascript
javascript相等运算符与等同运算符详细介绍
2013/11/09 Javascript
使用delegate方法为一个tr标签加一个链接
2014/06/27 Javascript
jQuery中DOM树操作之使用反向插入方法实例分析
2015/01/23 Javascript
node.js require() 源码解读
2015/12/13 Javascript
javascript显示倒计时控制按钮的简单实现
2016/06/07 Javascript
浅谈jquery中的each方法$.each、this.each、$.fn.each
2016/06/23 Javascript
前端分页功能的实现以及原理(jQuery)
2017/01/22 Javascript
web前端vue之vuex单独一文件使用方式实例详解
2018/01/11 Javascript
vue.js使用代理和使用Nginx来解决跨域的问题
2018/02/03 Javascript
浅谈Vue.js路由管理器 Vue Router
2018/08/16 Javascript
vue.js实现会动的简历(包含底部导航功能,编辑功能)
2019/04/08 Javascript
详解微信小程序支付流程与梳理
2019/07/16 Javascript
深入浅析vue中cross-env的使用
2019/09/12 Javascript
解决ant-design-vue中menu菜单无法默认展开的问题
2020/10/31 Javascript
[30:00]完美世界DOTA2联赛PWL S2 Rebirth vs LBZS 第二场 11.28
2020/12/01 DOTA
python统计日志ip访问数的方法
2015/07/06 Python
利用python获取某年中每个月的第一天和最后一天
2016/12/15 Python
一个基于flask的web应用诞生 flask和mysql相连(4)
2017/04/11 Python
解决安装tensorflow遇到无法卸载numpy 1.8.0rc1的问题
2018/06/13 Python
Python标准库itertools的使用方法
2020/01/17 Python
iHerb台湾:维生素、保健品和健康产品
2018/01/31 全球购物
英国健康和美容技术产品购物网站:CurrentBody
2019/07/17 全球购物
暑假实习求职信范文
2013/09/22 职场文书
《分一分》教学反思
2014/04/13 职场文书
2014银行领导班子四风对照检查材料思想汇报
2014/09/25 职场文书
警察群众路线整改措施
2014/09/26 职场文书
干部考察材料范文
2014/12/24 职场文书
总经理助理岗位职责
2015/01/31 职场文书
新入职员工工作总结
2015/10/15 职场文书
2019开业庆典剪彩仪式主持词!
2019/07/22 职场文书
Python OpenCV 图像平移的实现示例
2021/06/04 Python