web前台入门到实战:送给CSS初学者的悬停过渡动画三部曲
CSS不肯定要写得多么复杂才能实现特殊效果。如下就是三个超级简单的过渡的例子,可能只是几行代码,但是增加到Web应用程序中,却会让它增色不少。

如下是我们将在本教程中构建的代码
项目设置
在这个项目中,我们将把过渡效果应用到一个class为box的元素上面。这个box元素内部是垂直和水平居中的文字内容。HTML结构相当简单:
<div class='box'> <p>TEXT</p></div>CSS代码也一样简单。我们想要使用无衬线字体,并确保div中的段落文本是白色的,可以通过如下代码来实现:
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 */}专门建立的学习Q-q-u-n: 731771211,分享学习方法和需要注意的小细节,不停升级最新的教程和学习技巧(从零基础开始到前台项目实战教程,学习工具,全栈开发学习路线以及规划)- 无论你对CSS的过渡属性熟习与否,我们在这里都来简要详情一下,一共分为三步。.第一步,我们需要将它应用到all变化的属性。接下来,设置过渡时长为0.25秒。最后,将动画函数选为ease。ease的体现状态就是起止过程比较缓慢,中间过渡迅速。
holly high! 目前准备工作都已经就绪,接下来就是增加过渡效果了。到目前为止,div看起来应该像下面这样。

- 褪色效果
首先,增加一个褪色的过渡。新建一个div元素,并为它增加一个名为fade的类:
<div class='box fade'> <p>FADE HERE</p></div>接下来我们所需要做的就是为这个fade类指定悬停规则。我们需要借助CSS伪类选择器:hover来完成这件事情。这个伪类选择器对所有的元素都有效,并且会在元素处于鼠标指针悬停状态下的时候激活CSS公告。基于此,我们借助:hover选择器将div的透明度改为0.5:
.fade:hover { opacity: 0.5;}简单吧。上面这句CSS公告就为div指定了一个悬停效果。如下就是目前它展示的样子。而你之所以能够看到过渡样式,是由于我们一开始在名为box的类中使用了transition:all 0.25s ease;的公告。看下面,是不是一个还不错的褪色效果:

- 来点颜色看看
指定一个变色过渡其实和褪色过渡的过程殊途同归。首先,创立一个div元素,并为它增加一个名为color的类。
<div class='box color'> <p>COLOR HERE</p></div>同样地,我们也要借助:hover选择器来帮我们完成这件事,但是这一次我们不是改变透明度而是背景色:
.color:hover { background: #FF5722;}如下就是实际效果了:

- 一起摇摆
接下来,来实现一个摆动的效果。这个效果实现起来比前面的两个例子稍显复杂。在这个例子中,我会采用@keyframes来完成。
@keyframes——赋予你在一个CSS动画序列中控制中间步骤的魔力。
首先还是一样,你一定已经听烦了,创立一个div元素,并未它增加一个名为wiggle的类:
<div class='box wiggle'> <p>WIGGLE WIGGLE</p></div>接下来,我们要做的就是借助@keyframes来创立动画。我们先给动画起个名字,就叫wiggle吧。并在如下的代码中增加抖动效果的实现:
专门建立的学习Q-q-u-n: 731771211,分享学习方法和需要注意的小细节,不停升级最新的教程和学习技巧(从零基础开始到前台项目实战教程,学习工具,全栈开发学习路线以及规划)@keyframes wiggle { 20% { transform: translateX(4px); } 40% { transform: translateX(-4px); } 60% { transform: translateX(2px); } 80% { transform: translateX(-1px); } 100% { transform: translateX(0); }}从上面的代码已经可以看出,@keyframes赋予我们将动画分解成单步,并且准确定义每一步发生了什么的能力。通过百分比的方式指定动画的进度:
- 20%——div相对于初始位置右移4px。
- 40%——div相对于初始位置左移4px。
- 60%——div相对于初始位置右移2px。
- 80%——div相对于初始位置左移1px。
- 100%——div恢复到初始位置。
现在我们就能借助:hover选择器来展现wiggle的动画了:
.wiggle:hover { animation: wiggle 1s ease; animation-iteration-count: 1;}我们将animation设置成wiggle。同时希望动画持续1秒的时长,采用ease的动画效果。
最后,就是指定动画在每次鼠标指针悬停的时候触发一次。
下图就是最终的动画效果:

1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » web前台入门到实战:送给CSS初学者的悬停过渡动画三部曲