CSS动画很是的有趣;这种技术的美就在于,经过使用不少简单的属性,你能建立出漂亮的消隐效果。其中表明性的一种就是CSS图片翻转效果,能让你看到一张卡片的正反两面上的内容。本文就是要用最简单的方法向你们介绍如何建立这种效果。javascript
网上有不少其它的教材,但里面添加了不少多余的代码样式,须要读者去分清哪些是必要的,那些是无用的;本文避免了这些问题,只列出了必要的CSS代码,你能够在其上添加本身喜欢的风格来美化这些卡片。
实现正反面效果的HTML代码,估计你也能想到应该是这样的:css
<div class="flip-container" ontouchstart="this.classList.toggle('hover');"> <div class="flipper"> <div class="front"> <!-- 前面内容 --> </div> <div class="back"> <!-- 背面内容 --> </div> </div> </div>
正如你想到的,应该有两个容器,分别存放卡片“前面”和“背面”,经过CSS,咱们会指定这两个容器元素本身的做用。还有须要注意的是ontouchstart
这段js,它能让你使用触屏来触发翻转动做。显然,你应该把这段代码单独提取出来,让JavaScript代码放到一块儿。html
/* 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); }
下面是大概的整个过程的原理:java
这就是所有这些代码的做用!你把这段代码放到你的网页里,而后修饰一下卡片的样式就好了!web
注:对卡片元素的 某些属性设置一些特定的值(例如)(likeoverflow: hidden
)会致使其子元素丧失3D变换功能。我承认他的观点,由于正是在本文的例子中我正好遇到了overflow: hidden
相关的麻烦,它致使了3D变换子元素全都出如今了同一个平面上,有几个是被旋转了180度。
若是你喜欢用JavaScript来触发翻转动做,下面这个简单的css样式类就能帮你作到这样:浏览器
.flip-container:hover .flipper, .flip-container.hover .flipper, .flip-container.flip .flipper { transform: rotateY(180deg); }
使用javascript
给容器元素添加这个css flip
类就能触发卡片翻转——不须要用户悬停鼠标在上面。用document.querySelector("#myCard").classList.toggle("flip")
实现它!ide
执行竖向翻转也很简单,跟横向翻转同样,只须要修改一下 transform-origin
的值,而后让它按X轴旋转。post
.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尚未实现现代浏览器中的transform
功能。基本的作法就是对正面和背面两个卡片同时分别翻转:this
/* 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动画来讲这种效果很是的实用,能够说完美。