您现在的位置是:网站首页> 编程资料编程资料
CSS图片翻转动画技术详解(IE也实现了)利用纯css实现图片翻转的效果一款基于css3麻将筛子3D翻转特效的实例教程css3实现3D色子翻转特效一款利用纯css3实现的360度翻转按钮的实例教程CSS滤镜实现的颜色渐变翻转效果 纯CSS实现菜单、导航栏的3D翻转动画效果css控制列表与导航的制作(水平导航条、垂直翻转的列表、垂直导航栏、内css3的图形3d翻转效果应用示例CSS旋转与翻转使用示例详解CSS Cookbook 创建文字导航菜单和翻转特效
2021-09-06
1018人已围观
简介 因为不断有人问我,现在我补充一下:IE是支持这种技术的!尽管会很麻烦。需要做的是旋转front和back元素,而不是旋转整个容器元素。如果你使用的是最新版的IE,可以忽略这一节。IE10+是支持的,IE9完全不支持CSS动画。
CSS动画非常的有趣;这种技术的美就在于,通过使用很多简单的属性,你能创建出就连皮克斯动画制作公司也会赞叹的漂亮的消隐效果。其中代表性的一种就是CSS图片翻转效果,能让你看到一张卡片的正反两面上的内容。本文就是要用最简单的方法向大家介绍如何创建这种效果。
简单说明:这并不是第一篇我介绍这种技术的文章,但我发现那些都过于复杂了。网上还有很多其它的教材,但里面添加了很多多余的代码样式,需要读者去分清哪些是必要的,那些是无用的;本文避免了这些问题,只列出了必要的CSS代码,你可以在其上添加自己喜欢的风格来美化这些卡片。
HTML代码
实现正反面效果的HTML代码,估计你也能想到应该是这样的:
正如你想到的,应该有两个容器,分别存放卡片“前面”和“背面”,通过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);
}
.flip-container, .front, .back {
width: 320px;
height: 480px;
}
/* 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;
}
/* front pane, placed above back */
.front {
z-index: 2;
}
/* 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;
}
.vertical .back {
transform: rotateX(180deg);
}
.vertical.flip-container .flipper {
transform-origin: 100% 213.5px; /* 高的一半 */
}
.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);
}
.flip-container, .front, .back {
width: 320px;
height: 480px;
}
/* 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;
transition: 0.6s;
transform-style: preserve-3d;
position: absolute;
top: 0;
left: 0;
}
/* UPDATED! front pane, placed above back */
.front {
z-index: 2;
transform: rotateY(0deg);
}
/* back, initially hidden pane */
.back {
transform: rotateY(-180deg);
}
/*
Some vertical flip updates
*/
.vertical.flip-container {
position: relative;
}
.vertical .back {
transform: rotateX(180deg);
}
.vertical.flip-container:hover .back {
transform: rotateX(0deg);
}
.vertical.flip-container:hover .front {
transform: rotateX(180deg);
}
使用上面的这段代码,IE10里也能正确的进行卡片翻转了!
这个CSS卡片翻转动画技术一直是一个经典的案例,代表着CSS动画能够实现的效果,甚至3DCSS动画能实现的强大效果。优点就是使用的代码很少很简单。对于制作HTML5动画来说这种效果非常的实用,可以说完美。你还能想到其它用到这个效果的地方吗?
相关内容
- 使用CSS媒体查询(Media Queries)和JavaScript判断浏览器设备类型的方法CSS3中媒体查询结合rem布局适配手机屏幕纯js和CSS3媒体查询制作简单的响应式导航菜单特效源码详解CSS3 Media Queries中媒体属性的使用 CSS3媒体查询Media Queries基础学习教程CSS3媒体查询(Media Queries)介绍css3 响应式媒体查询的示例代码
- css3实现input输入框颜色渐变发光效果代码纯CSS3实现漂亮的input输入框动画样式库(Text input love)
- CSS2书写顺序包括位置属性、自身属性、文字系列CSS的border属性值具有可读性的书写顺序CSS书写规范、顺序和命名规则Mozilla建议的css书写顺序CSS样式书写顺序和命名规范及注意事项
- CSS(html)背景图优化合并深入探讨CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- 通过浮动+定位实现两个div在同一行设置div背景透明的方法示例CSS实现div不设高度完全居中div自适应高度自动填充剩余高度详解DIV+CSS的命名规矩才能有利于SEO优化的实现方法DIV或者DIV里面的图片水平与垂直居中的方法详解如何用div实现自制滚动条div对齐与网页布局详解DIV+CSS实现电台列表设计的示例代码div+css实现带箭头的面包屑导航栏不定宽高的文字在div中垂直居中实现方法
- 兼容IE6的网页最小最大宽度和最小最大高度css写法
- IE浏览器专有css属性之zoom详解详解CSS中zoom属性或overflow:auto属性清除浮动的作用CSS中的zoom属性和scale属性的用法及区别CSS中不为人知Zoom属性的使用介绍(IE私有属性)css中zoom:1属性的定义和作用
- IE6下伪类hover失效问题及解决办法a标签的四个css伪类(link、visited、hover、active)样式理解csshover.htc在IE7下使用:active伪类无效解决方法ie6不支持hover ie6 标签(除a标签)不支持伪类:hover解决方案关于伪类hover的一些总结(推荐)
- CSS通过RGBa将一个元素设置为透明效果rgba中的a是什么意思 CSS之RGBA颜色指南颜色之ARGB与RGB、RGBA的区别与介绍详解css透明度之rgba和opacity的区别及兼容css中使用rgba和opacity设置透明度的区别(附图)完美解决IE8下不兼容rgba()的问题CSS3中使用RGBa来调节透明度的教程CSS3 RGBA色彩模式使用实例讲解CSS3的RGBA中关于整数和百分比值的转换CSS3中使用RGBA设置透明度的示例CSS3 透明色 RGBA使用介绍
- css样式的动态添加及显示和隐藏等零碎用法CSS文本超出指定宽度后隐藏并显示为省略号的实现方法利用css的样式对文本进行隐藏和显示等操作css样式显示省略号自定义宽度超过隐藏显示省略标记纯css3显示隐藏一个div特效的具体实现css和jquery设置文字的显示和隐藏利用CSS3的checked伪类实现OL的隐藏显示的方法从A页面连接到B页面后并直接把B页面的隐藏层显示-CSS教程-网页制作-网CSS实现隐藏和显示功能的代码