css实现动画的方法(CSS实现悬停过渡动画三部曲)
css实现动画的方法
CSS实现悬停过渡动画三部曲CSS不一定要写得多么复杂才能实现特殊效果。如下就是三个超级简单的过渡的例子,可能只是几行代码,但是添加到Web应用程序中,却会让它增色不少。
如下是我们将在本教程中构建的代码项目设置在这个项目中,我们将把过渡效果应用到一个class为box的元素上面。这个box元素内部是垂直和水平居中的文字内容。
HTML结构相当简单:
<li class='box'> <p>TEXT</p> </li>
CSS代码也一样简单。我们想要使用无衬线字体,并确保li中的段落文本是白色的,可以通过如下代码来实现:
body { color: white; font-family: Helvetica, Sans-Serif; }
另外,给box元素添加如下CSS属性:
.box { width:200px; /* Set the Width of box */ height:50px; /* Set the Height of box */ background:#424242; /* Dark Grey Background color */ transition:all 0.25s ease; /* Transition settings */ display: flex; /* Use Flexbox on P */ align-items: center; /* Center P */ justify-content: center; /* Center P */ margin: 10px; /* Apply a margin around our Box */ }
无论你对CSS的过渡属性熟悉与否,我们在这里都来简要介绍一下,一共分为三步。
.第一步,我们需要将它应用到all变化的属性。接下来,设置过渡时长为0.25秒。最后,将动画函数选为ease。ease的表现状态就是起止过程比较缓慢,中间过渡迅速。holly high! 目前准备工作都已经就绪,接下来就是添加过渡效果了。到目前为止,li看起来应该像下面这样。
褪色效果首先,添加一个褪色的过渡。新建一个li元素,并为它添加一个名为fade的类:
<li class='box fade'> <p>FADE HERE</p> </li>
接下来我们所需要做的就是为这个fade类指定悬停规则。我们需要借助CSS伪类选择器:hover来完成这件事情。这个伪类选择器对所有的元素都有效,并且会在元素处于鼠标指针悬停状态下的时候激活CSS声明。基于此,我们借助:hover选择器将li的透明度改为0.5:
.fade:hover { opacity: 0.5; }
简单吧。上面这句CSS声明就为li指定了一个悬停效果。如下就是目前它展现的样子。而你之所以能够看到过渡样式,是因为我们一开始在名为box的类中使用了transition:all 0.25s ease;的声明。看下面,是不是一个还不错的褪色效果:
2.来点颜色看看指定一个变色过渡其实和褪色过渡的过程异曲同工。
首先,创建一个li元素,并为它添加一个名为color的类。
<li class='box color'> <p>COLOR HERE</p> </li>
同样地,我们也要借助:hover选择器来帮我们完成这件事,但是这一次我们不是改变透明度而是背景色:
.color:hover { background: #FF5722; }
如下就是实际效果了:
3.一起摇摆接下来,来实现一个摆动的效果。
这个效果实现起来比前面的两个例子稍显复杂。在这个例子中,我会采用@keyframes来完成。@keyframes——赋予你在一个CSS动画序列中控制中间步骤的魔力。首先还是一样,你肯定已经听烦了,创建一个li元素,并未它添加一个名为wiggle的类:
<li class='box wiggle'> <p>WIGGLE WIGGLE</p> </li>
接下来,我们要做的就是借助@keyframes来创建动画。我们先给动画起个名字,就叫wiggle吧。并在如下的代码中添加抖动效果的实现:
@keyframes wiggle { 20% { transform: translateX(4px); } 40% { transform: translateX(-4px); } 60% { transform: translateX(2px); } 80% { transform: translateX(-1px); } 100% { transform: translateX(0); } }
从上面的代码已经可以看出,@keyframes赋予我们将动画分解成单步,并且精确定义每一步发生了什么的能力。通过百分比的方式指定动画的进度:20%——li相对于初始位置右移4px。40%——li相对于初始位置左移4px。60%——li相对于初始位置右移2px。80%——li相对于初始位置左移1px。100%——li恢复到初始位置。现在我们就能借助:hover选择器来展示wiggle的动画了:
.wiggle:hover { animation: wiggle 1s ease; animation-iteration-count: 1; }
我们将animation设置成wiggle。同时希望动画持续1秒的时长,采用ease的动画效果。最后,就是指定动画在每次鼠标指针悬停的时候触发一次。下图就是最终的动画效果:
总结
以上所述是小编给大家介绍的CSS实现悬停过渡动画三部曲,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!
- css3动画实现loading(CSS3实现粒子旋转伸缩加载动画)
- html5+canvas动画(解析html5 canvas实现背景鼠标连线动态效果代码)
- html5图片动画制作(HTML5 3D旋转相册的实现示例)
- css3弹出动画效果(CSS3实现跳动的动画效果)
- 简述css3动画与过渡效果(CSS3制作翻转效果_动力节点Java学院整理)
- css3动画效果怎么调(CSS3动画之流彩文字效果+图片模糊效果+边框伸展效果实现代码合集)
- css3引导动画教程(详解Css3新特性应用之过渡与动画)
- css3渐变色动画代码(CSS3 实现的动态星空背景)
- canvas实现滚动列表(Canvas实现贝赛尔曲线轨迹动画的示例代码)
- css3动画平移代码(利用CSS3实现炫酷的飞机起飞动画)
- css3左右移动动画效果(CSS3鼠标悬浮过渡缩放效果)
- css3设置动画无限循环(css3 实现文字闪烁效果的三种方式示例代码)
- css3背景渐变动画效果(css3制作的背景渐变动画效果)
- css动画的性能(你所不知道的 CSS 动画技巧与细节)
- jquery隐藏动画教程(jquery插件实现鼠标隐藏)
- 只用html5简单动画代码(HTML5 3D书本翻页动画的实现示例)
- 王伦狭隘,晁盖霸道,宋江奸诈骨头软,只有鲁智深才适合当寨主(王伦狭隘晁盖霸道)
- 他是梁山最早的头目,江湖人称 旱地忽律 ,宋江几乎将其遗忘(他是梁山最早的头目)
- 梁山创始人杜迁,为何不受宋江待见,只排名83位(梁山创始人杜迁)
- 法国面包(法国面包法棍)
- 微信(微信分身)
- 双十二(双十二和双十一哪个划算)
热门推荐
- php 大文件切片(PHP大文件切割上传功能实例分析)
- laravel使用队列(基于laravel where的高级使用方法)
- sqlserver栏位说明(SQL Server重置IDENTITY属性种子值操作)
- jQuery 右侧浮动导航菜单
- 微信小程序开发模式(微信小程序引入Vant框架的全过程记录)
- tomcat怎么知道访问servlet(详解从源码分析tomcat如何调用Servlet的初始化)
- python柱状图第四节(python使用Plotly绘图工具绘制柱状图)
- html怎么设置地图(HTML5获取当前地理位置并在百度地图上展示的实例)
- 访问云服务器磁盘文件路径(云服务器的磁盘要怎么选择?)
- macos安装虚拟机教程(VMware虚拟机安装苹果Mac OS的超详细教程)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9