摘要:所以给父元素添加至此,就实现了一个翻转卡牌的效果,但是这里需要解决一个问题,因为属性不被支持支持,所以需要进行降级,我的做法是直接显示隐藏。
今天在工作中遇到需求,需要用CSS3写一个卡片翻转效果,这个效果看起来简单,但是还是涉及到一些不常用的CSS3中的3D转换的属性以及实现该效果的思路,所以这里总结一下。
原文链接:http://mrzhang123.github.io/2016/08/17/FlipCards/
项目地址:https://github.com/MrZhang123/Practice/tree/master/FlipCards
需要的CSS3属性 perspective目前浏览器都不支持perspective属性
在chrome和Safari中需要使用-webkit-perspective,而在Firefox中需要使用-moz-perspective来定义。
定义和用法perspective属性定义3D元素距视图的距离,以像素计。该属性允许改变查看3D元素的视图。当为元素定义
perspective属时,其子元素会获得透视效果,而不是元素本身。换句话说,设置这个元素是为了给该元素的子元素用。
值number:元素距离视图的距离,以像素计
none:默认值,与0相同。不设置透视
transform-styleFirefox支持transfrom-style属性。
Chrome、Safari和Opera支持代替的-webkit-transform-style属性。
定义和用法transform-style属性固定如何在3D空间中呈现被嵌套的元素。一般给父元素设置让其所有子元素跟着父元素一起位置移动,一般会设置。
值flat:子元素将不保留其3D位置(默认值)
perserve-3d:子元素将保留其3D位置
transitionIE10+、Firefox、Opera、Chrome均支持transition属性。Safari支持替代的-webkit-transition属性。但是IE9-不支持该属性。
定义和用法transition属性是一个简写属性,用于设置四个过渡属性:
transiton-property:规定设置过渡效果的CSS属性的名称
transiton-duration:规定完成过渡效果需要多少秒或毫秒
transiton-timing-funciton:规定速度效果的速度曲线
transition-delay:规定过渡效果何时开始
transiton-duration必须设置,否则时长为0 ,不会有过渡效果
backface-visibility只有IE10+和Firefox支持backface-visibility,Opera15+、Safari和Chrome支持替代的-webkit-backface-visibility
定义和用法backface-visibility属性定义当前元素不面向屏幕时是否可见,如果元素在旋转后不希望看到背面,则可以使用。
visible:背面是可见的(默认值)
hidden:背面是不可见的
实现的思路要实现类似的翻牌效果,首先我们需要有一张可以翻的牌,这张牌由两个元素重叠组成,位于上层正面我们看到,而位于下层的背面我们看不到并且本身是绕Y轴旋转过的,这样,当鼠标移动上去后,同时让正面和背面执行旋转就可以实现翻牌效果。
实现基本结构代码如下:
ul,li { margin:0; padding:0; list-style:none; } #content ul li{ width: 225px; height: 180px; } #content ul li a{ position: relative; display: block; width: 100%; height: 100%; } #content ul li a > div{ position: absolute; left: 0; height: 0; width: 100%; height: 100%; color: #fff; } #content ul li a div:first-child{ background-color: rgb(255, 64, 129); z-index:2; } #content ul li a div:last-child{ background:rgb(0, 188, 212); z-index:1; } #content ul li a div h3{ margin: 0 auto 15px; padding: 15px 0; width: 200px; height: 16px; line-height: 16px; font-size: 14px; text-align: center; border-bottom: 1px #fff dashed; } #content ul li a div p{ padding: 0 10px; font-size: 12px; text-indent: 2em; line-height: 18px; }
这样就让两个div叠在一起了,但是如果要进行翻转的话,首先是需要将背面本身就翻过去,当鼠标放上去之后翻转过来,让我们看到,所以我们需要给背面添加翻转180°的属性,鼠标放上去之后让它翻转到0°,同时为保证每个浏览器渲染统一,给正面加一个翻转0°,鼠标移动上去之后翻转-180°,并且是一个动画,所以要添加过渡。所以给正面背面添加CSS如下:
#content ul li a > div{ -webkit-transition:.8s ease-in-out; -moz-transition:.8s ease-in-out; } #content ul li a div:first-child{ -webkit-transform:rotateY(0); -moz-transform:rotateY(0); } #content ul li a div:last-child{ -webkit-transform:rotateY(180deg); -moz-transform:rotateY(180deg); } #content ul li a:hover div:first-child{ -webkit-transform:rotateY(-180deg); -moz-transform:rotateY(-180deg); } #content ul li a:hover div:last-child{ -webkit-transform:rotateY(0); -moz-transform:rotateY(0); }
在添加这些CSS3属性后,可以实现翻转,但是发现只看到正面,没有看到背面,这又是为什么呢,前面提到有一个属性backface-visibility,这个属性用于控制在翻转后,元素的背面是否可见,默认是可见的,所以就会挡着背面那个元素,我们需要手动设置元素翻转后背面不可见,所以需要设置:
#content ul li a > div{ -webkit-backface-visibility: hidden; -moz-backface-visibility: hidden; }
这样设置之后,由于正面的元素在翻转后背面不可见,我们就可以看到背面的元素了。
但是,仔细观察会发现这个翻转似乎并不是那么立体,似乎在两条平行线之间实现了翻转,所以我们需要设置一个观察点距离视图的距离,这时候就需要给父元素添加perspective属性,这个属性的值一般为800px ~ 1000px,这个范围内的值会看上去合理。所以给父元素添加:
#content ul li a{ -webkit-perspective: 800px; -moz-perspective: 800px; }
至此,就实现了一个翻转卡牌的效果,但是这里需要解决一个问题,因为perspective属性不被IE支持(Microsoft Edge支持),所以需要进行降级,我的做法是直接显示隐藏。那么如何识别IE9+浏览器呢?在stackoverflow中我找到了答案:
附:CSS中识别各类IE的方法 IE6* html .ie6{ property:value; }
or
html .ie6{ _property:value; }IE7
*+html .ie7{ property:value; }
or
*:first-child+html ie7{ property:value; }IE6 and IE7
@media screen9{ ie67{property:value;} }
or
.ie67{ *property:value;}
or
.ie67{ #property:value;}IE6,7 and 8
@media screen,screen9{ ie678{property:value;} }IE8
html>/**/body .ie8{property:value;}
or
@media screen{ ie8{property:value;} }只在IE8标准模式
.ie8{property/***/:value9;}IE8,9 and 10
@media screen { ie8910{property:value;} }IE9 only
@media screen and (min-width:0 ) and (min-resolution: .001dpcm){ /*IE9 CSS*/ .ie9{property:value;} }IE9+
@media screen and (min-width:0 ) and (min-resolution: +72dpi){ /*IE9+ CSS*/ .ie9up{property:value;} }IE9 and 10
@media screen and (min-width:0){ .ie910{property:value;} }IE10 only
_:-ms-lang(x), ie10 {property:value;}IE10+
_:-ms-lang(x), ie10up{property:value;}
or
@media all and (-ms-high-contrast:none),(-ms-high-contrast:active){ .ie10up{property:value;} }IE11+
_:-ms-fullscreen, :root .ie11up{property:value;}
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/111456.html
摘要:所以给父元素添加至此,就实现了一个翻转卡牌的效果,但是这里需要解决一个问题,因为属性不被支持支持,所以需要进行降级,我的做法是直接显示隐藏。 今天在工作中遇到需求,需要用CSS3写一个卡片翻转效果,这个效果看起来简单,但是还是涉及到一些不常用的CSS3中的3D转换的属性以及实现该效果的思路,所以这里总结一下。 原文链接:http://mrzhang123.github.io/2016/...
摘要:作为前端开发人员的必修课,翻转能带我们完成许多基本动效,本期我们将用实现翻转效果第一步非常简单,我们简单画个演示方块,为其添加和属性本示例均使用语法我们看一看这时候的效果这里需要注意的是属性要写在上而不是上,如果只在上写,则鼠标移出时并没有作为前端开发人员的必修课,CSS3翻转能带我们完成许多基本动效,本期我们将用CSS3实现hover翻转效果~ 第一步非常简单,我们简单画1个演示方块,为其...
摘要:分析代码如下标签里包裹一个盒子里包裹两个,为效果的前后面做准备。分析外观定位代码如下效果首先创造环境,保留空间在的时候,我们让旋转,正面面对我们的元素向上翻转,下面有元素翻转上来,并且在翻转时有一个凸出来的效果。 效果预览 showImg(https://segmentfault.com/img/bVqF6k);分析:可以看出hover的时候是有前后两个面的翻转,并且有一个凸出效果。 ...
摘要:动画以低速开始,然后加快,在结束前变慢。在函数中自己的值。在所指定的一段时间内,在动画显示之前,应用开始属性值在第一个关键帧中定义。动画调用语法 animation: bounceIn 0.3s ease 0.2s 1 both; 按顺序解释参数: 动画名称 如:bounceIn 一周期所用时间 如:0.3s 速度曲线 如:ease 值 描述 linear 动画从头...
阅读 1658·2019-08-30 15:55
阅读 980·2019-08-30 15:44
阅读 872·2019-08-30 10:48
阅读 2045·2019-08-29 13:42
阅读 3188·2019-08-29 11:16
阅读 1268·2019-08-29 11:09
阅读 2059·2019-08-26 11:46
阅读 620·2019-08-26 11:44