CSS3图片翻转动画技术详解

编程之家收集整理的这篇文章主要介绍了CSS3图片翻转动画技术详解编程之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

网上有很多其它的教材,但里面添加了很多多余的代码样式,需要读者去分清哪些是必要的,那些是无用的;本文避免了这些问题,只列出了必要的CSS代码,你可以在其上添加自己喜欢的风格来美化这些卡片。

HTML代码

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

<div class="flip-container" ontouchstart="this.classList.toggle('hover');">
    ="flipper">
        ="front">
            <!-- 前面内容 -->
        </div="back" 背面内容 >
>

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

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,1)">
    backface-visibility: hidden; 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度,这样让它扮演背面的角色。

这就是全部这些代码的作用!你把这段代码放到你的网页里,然后修饰一下卡片的样式就行了!

注:对卡片元素的某些属性设置一些特定的值(例如)(like overflow: hidden)会导致其子元素丧失3D变换功能。我认可他的观点,因为正是在本文的例子中我正好遇到了overflow: hidden相关的麻烦,它导致了3D变换子元素全都出现在了同一个平面上,有几个是被旋转了180度。

触发CSS翻转

如果你喜欢用JavaScript来触发翻转动作,下面这个简单的css样式类就能帮你做到这样:

.flip-container:hover .flipper,.flip-container.hover .flipper,.flip-container.flip .flipper { rotateY(180deg);
}

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

CSS竖向翻转

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

.vertical.flip-container {
    position: relative;
}

    .vertical .back { rotateX(180deg);
    }

    .vertical.flip-container .flipper {
        transform-origin: 100% 213.5px;  高的一半 */
    }

    .vertical.flip-container:hover .flipper { rotateX(-180deg);
    }

注意这里用的是rotateX,而不是之前的rotateY

让IE支持这种动画技术

需要针对IE对这段标准的卡片翻转代码进行特殊的修改,因为IE还没有实现现代浏览器中的transform功能。基本的做法就是对正面和背面两个卡片同时分别翻转:

 1000; preserve-3d;
}
      UPDATED! flip the pane when hovered 
    .flip-container:hover .back { rotateY(0deg);
    }
    .flip-container:hover .front {  UPDATED! front pane,1)"> 2; rotateY(0deg);
}

 rotateY(-180deg);
}

 
    Some vertical flip updates 

.vertical.flip-container {

    .vertical.flip-container:hover .back { rotateX(0deg);
    }

    .vertical.flip-container:hover .front { rotateX(180deg);
    }

使用上面的这段代码,IE10里也能正确的进行卡片翻转了!

这个CSS卡片翻转动画技术一直是一个经典的案例,代表着CSS动画能够实现的效果,甚至3DCSS动画能实现的强大效果。优点就是使用的代码很少很简单。对于制作HTML5动画来说这种效果非常的实用,可以说完美。

参考地址

总结

以上是编程之家为你收集整理的CSS3图片翻转动画技术详解全部内容,希望文章能够帮你解决CSS3图片翻转动画技术详解所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢寻找一群志同道合、互帮互助的学习伙伴,可以点击下方链接加入:
编程之家官方1群:1065694478(已满)
编程之家官方2群:163560250(已满)
编程之家官方3群:312128206

相关文章

猜你在找的HTML5相关文章

概述 WeUI是一套同微信原生视觉体验一致的基础样式库,为微信Web开发量身设计,可以令用户的使用感知更加统一。包含button、cell、dialog、toast、article、icon等各式元素
在新的HTML5标准中,新增了一个非常重要的元素—canvas元素。使用该元素,可以在页面中直接进行各种复杂图形的制作。因此,如果使用该元素绘制统计图,比之前使用服务器端控件来生成统计图的方法更加具有
ReactJS通常也被称为&quot;React&quot;,是一个刚刚在这场游戏中登场的新手。它由Facebook创建,并在2013年首次发布。Facebook认为React在处理SPA问题上可以成
又到了一年一度的中国春运,今年的网络订票(12306.cn)有好多的故事上演,下面几条是这两天的几条相关新闻。猎豹浏览器推出春运抢票版 九大优势轻松订票抢票插件风靡的恶果:农民工成购车票弱势群体123
Twitter发布了Flight项目。Flight是一个轻量级的、基于组件的JavaScript框架,可以将行为映射到DOM节点上。Twitter将其用在自己的Web应用上,Twitter基于MIT许
JayData 是一个标准的、跨平台的库和方法,用于访问和操作各种不同的数据源,最适合用于 JavaScript 和 HTML5 应用。 官方网站:http://jaydata.org/ ASP.NE
简洁优雅的 Twitter Bootstrap Metro 界面风格开发框架,是 GitHub 上的开源项目http://talkslab.github.com/metro-bootstrap 。Me
XB 软件公司最近发布了JavaScript UI 库Webix ,其中包含的组件超过45个,用这些组件可以构建跟HTML5 和 CSS3 兼容的程序,这些程序不仅能在个人电脑上运行,还能用在iOS、