• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > CSS图片翻转动画技术详解(IE也实现了)

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

作者:佚名 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含css翻转图片,css翻转,css3翻转,css3动画等相关知识,佚名 希望在学习及工作中可以帮助到您

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

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

HTML代码

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


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

CSS代码

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

}</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样式类就能帮你做到这样:

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

CSS竖向翻转

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

}</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功能。基本的做法就是对正面和背面两个卡片同时分别翻转:

}</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动画来说这种效果非常的实用,可以说完美。你还能想到其它用到这个效果的地方吗?

您可能想查找下面的文章:

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

相关文章

  • 2017-08-06深入解析CSS中margin属性的使用
  • 2017-08-06CSS框架开发指南
  • 2017-08-06css教程实现div背景色渐变色代码分享
  • 2017-08-06CSS实现的中英文双语菜单效果代码
  • 2017-08-06select元素中设置padding效果的方法
  • 2017-08-06CSS3实现可关闭的下拉手风琴菜单效果
  • 2017-08-06外部引用CSS中 link与@import的区别
  • 2017-08-06使用CSS3在触屏上为按钮实现激活效果
  • 2017-08-06强制CSS !important使用介绍
  • 2017-08-06css样式图片、渐变、相关小知识(必看)

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • CSS 清除浮动Clear
    • css中让元素隐藏的多种方法
    • 使用CSS的position属性控制页面布局的入门教程
    • CSS样式简单实现Table没有外边框只有内边框
    • 15个CSS常识 注意一下吧
    • CSS画出各种三角形如等边三角形
    • 发现两个有趣的CSS3动画效果
    • CSS的一些圆角图形实例分享
    • 使用css3和jquery实现可伸缩搜索框
    • CSS代码使纯英文数字自动换行的简单实现

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有