因为不断有人问我, 现在我补充一下: IE 是支持这种技术的! 尽管会很麻烦. 需要做的是旋转 front 和 back 元素, 而不是旋转整个容器元素. 如果你使用的是最新版的 IE, 可以忽略这一节. IE10 + 是支持的, IE9 完全不支持 CSS 动画.
CSS 动画非常的有趣; 这种技术的美就在于, 通过使用很多简单的属性, 你能创建出就连皮克斯动画制作公司也会赞叹的漂亮的消隐效果. 其中代表性的一种就是 CSS 图片翻转效果, 能让你看到一张卡片的正反两面上的内容. 本文就是要用最简单的方法向大家介绍如何创建这种效果.
简单说明: 这并不是第一篇我介绍这种技术的文章, 但我发现那些都过于复杂了. 网上还有很多其它的教材, 但里面添加了很多多余的代码样式, 需要读者去分清哪些是必要的, 那些是无用的; 本文避免了这些问题, 只列出了必要的 CSS 代码, 你可以在其上添加自己喜欢的风格来美化这些卡片.
- (鼠标移到图片上看翻转效果)
- webHek
歪脖骇客 @歪脖骇客 Mozilla Web Developer, MooTools & jQuery Consultant, MooTools Core Developer, JavaScript Fanatic, CSS Tinkerer, PHP Hacker, and Web lover.
html 代码
实现正反面效果的 HTML 代码, 估计你也能想到应该是这样的:
- <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 代码放到一起.
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);
- }
下面是大概的整个过程的原理:
在最外层的容器元素上设置整个动画区域的透视 (perspective) 属性.
当外层容器元素遇到鼠标悬停事件时, 内部存放卡片的容器旋转 180 度. 这里也是控制旋转速度的地方. 如果将旋转值设置为 - 180deg, 是反向旋转.
表示卡片正面和背面的元素都要绝对定位, 这样它们才能在相同的位置相互遮挡. 它们的背面可视性 (backface-visibility) 属性设置为隐藏, 这样每个卡片的背面在翻转时都是看不见的.
将卡片的正面设置为一个比背面要高的 z-index 值, 这样保证卡片的正面在最上面.
将背面卡片旋转 180 度, 这样让它扮演背面的角色.
这就是全部这些代码的作用! 你把这段代码放到你的网页里, 然后修饰一下卡片的样式就行了!
来自 CSS 动画专家 Ana Tudor 的提示
对卡片元素的某些属性设置一些特定的值 (例如)(like overflow: hidden) 会导致其子元素丧失 3D 变换功能. 我认可他的观点, 因为正是在本文的例子中我正好遇到了 overflow: hidden 相关的麻烦, 它导致了 3D 变换子元素全都出现在了同一个平面上, 有几个是被旋转了 180 度.
触发 CSS 翻转
- (鼠标移到图片上看翻转效果)
- WebHek
歪脖骇客 @歪脖骇客 Mozilla Web Developer, MooTools & jQuery Consultant, MooTools Core Developer, JavaScript Fanatic, CSS Tinkerer, PHP Hacker, and Web lover.
触发翻转
如果你喜欢用 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 竖向翻转
- (鼠标移到图片上看翻转效果)
- WebHek
歪脖骇客 @歪脖骇客 Mozilla Web Developer, MooTools & jQuery Consultant, MooTools Core Developer, JavaScript Fanatic, CSS Tinkerer, PHP Hacker, and Web lover.
执行竖向翻转也很简单, 跟横向翻转一样, 只需要修改一下 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 动画来说这种效果非常的实用, 可以说完美. 你还能想到其它用到这个效果的地方吗?
(英文: Create a CSS Flipping Animation.)
来源: http://www.webhek.com/post/css-flip.html