实现鼠标hover动画效果自己理解的两种方法——练习笔记
练习前端技术学院的任务,需要实现“导航栏中的链接,随着鼠标悬浮的位置,相应的链接下出现红色线段”的效果(如图1),我的理解有简易与稍显复杂一些的方法:

首先想到的就是直接利用伪元素,改变其底边框状态即可。对应的代码及效果如下:
<html>
<head></head>
<body>
<div>
<ul>
<li><a href="#" class="Link-tit"><i>首页</i></a></li>
<li><a href="#" class="Link-tit"><i>最新活动</i></a></li>
<li><a href="#" class="Link-tit"><i>项目介绍</i></a></li>
<li><a href="#" class="Link-tit"><i>爱心社区</i></a></li>
<li><a href="#" class="Link-tit"><i>关于我们</i></a></li>
<li><a href="#" class="Link-tit"><i>登录</i></a></li>
</ul>
</div>
</body>
</html>
css为:
ul li{
width:120px;
float:left;
}
ul{
list-style-type:none;
}
div{float:right;/*实现整体的右对齐布局}
a:hover{
color:red;
border-bottom:3px solid red;/*实现鼠标悬浮时对应链接高亮红色且有红色底边框效果*/
}
此方法就没有了平滑的动作(动画效果),其效果如图:

另一方法是用CSS3属性transition(过渡)实现,思路是利用该属性指定鼠标动作时变化的具体属性以及时间来控制其变化,用一个空的<li>放置变化的红色底线,具体代码如下:
<html>
<head></head>
<body>
<div class="navigation"> <!--页眉导航栏-->
<ul>
<li><a href="#" class="Link-tit"><i>首页</i></a></li>
<li><a href="#" class="Link-tit"><i>最新活动</i></a></li>
<li><a href="#" class="Link-tit"><i>项目介绍</i></a></li>
<li><a href="#" class="Link-tit"><i>爱心社区</i></a></li>
<li><a href="#" class="Link-tit"><i>关于我们</i></a></li>
<li><a href="#" class="Link-tit"><i>登录</i></a></li>
<li class="move"></li> <!--利用一个空的<li>标签设置选中下划线-->
</ul>
</div>
</body>
</html>
CSS代码如下:
.head a{text-decoration:none;/*去除a自带的下划线*/}
ul{list-style-type:none;position:relative;}
.Link-tit:hover{color:red;}/*伪元素实现当鼠标停在链接上高亮显示*/
ul li{width:110px;float:left;line-height:20px;}
.move{border-bottom:3px solid red;position:absolute;left:0px;top:30px;
transition:left .2s ease-in-out 0s; /*transition中的left值为.move类事件触发时随鼠标变化的属性*/
-webkit-transition:left .2s ease-in-out 0s; /*chrome/safari浏览器*/
-moz-transition:left .2s ease-in-out 0s; /*firefox浏览器*/
-o-transition:left .2s ease-in-out 0s;} /*opera浏览器*/
li:nth-child(1):hover~.move{left:0px;}
li:nth-child(2):hover~.move{left:110px;}
li:nth-child(3):hover~.move{left:220px;}
li:nth-child(4):hover~.move{left:330px;}
li:nth-child(5):hover~.move{left:440px;}
li:nth-child(6):hover~.move{left:550px;}
其中,:nth-child(n)为子代选择器,此处表示各个链接,prev~slibings表示同辈元素,改变.move的left值,即可改变已经脱离文档流的下划线的位置,从而达到效果(见图一)。
transition:property(要进行过渡的属性) duration(过渡时间) timing-function(过渡变化曲线) delay(过渡开始时间)
实现鼠标hover动画效果自己理解的两种方法——练习笔记的更多相关文章
- /*去hover动画效果*/
<!DOCTYPE html> /*去hover动画效果*/ <html lang="en"> <head> <meta charset= ...
- Activity透明/半透明效果的设置transparent(两种实现方法)
两种方法实现Activity透明/半透明效果的设置,代码思路很有调理,感兴趣的朋友可以参考下,希望本文可以帮助到你 方法一:res/values文件夹下建立styles.xml: 复制代码代码如下 ...
- 两种方法使用js读写cookie实现一个底部广告浮层效果
下面一个案例实现了js实现一个页面浮层并且使用两种方法使用js读写cookie:来实现用户关闭广告的显示状态: 读者可以将下面代码复制到一个html文件试试效果:html的pre标签未两种js实现的方 ...
- 利用 :before :after伪类实现鼠标悬浮动画效果
1.最近在逛网站的时候,想找一下喜欢的鼠标悬浮效果,避免广告的嫌疑,直接放图了: 2.在实现的时候,如果在直接使用鼠标hover ,transform,进行过渡,不能达到想要的效果,因为同时只能触发一 ...
- css3 鼠标悬浮动画效果
CSS3案例 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <ti ...
- JQuery简单动画效果的发生顺序和animate方法
(1)在同一组元素上的效果 当在一个.animate()方法中以多个属性的方式应用时,是同时发生的. 当以方法连缀的形式应用时,是按顺序发生的(排队效果)---除非queue选项值为false. (2 ...
- 解决transition动画与display冲突的几种方法
如demo(如果没有显示,请查看源地址http://jsfiddle.net/ihardcoder/HNduT/2/)所示,基本的效果是在点击“Translate”按钮后,蓝色区域透明度变为0,然后隐 ...
- android动画(3)layout动画,layoutChanged动画及算定义它,ListViewActivity的Layout动画(代码和xm配置两种实现l)
1.layout切换动画 代码: 本示例是fragment切换.在它的oncreateView中 public class LayoutAnimationFrgmt extends Fragment ...
- jQuery 两种方法实现IE10以下浏览器的placeholder效果
/* ** jQuery版本:jQuery-1.8.3.min.js ** 测试的浏览器:IE8,IETester下的IE6-IE9** Author:博客园小dee */ placeholder是H ...
随机推荐
- 单独mybatis得使用
今天同学说要学习mybatis后来他写了个程序让我看看,我看了一下发现包引错了,他写的是单独的mybatis,引入的却是spring-mybatis,所以会报错. 今天我记录一下单独mybatis的使 ...
- scrapy使用PhantomJS爬取数据
环境:python2.7+scrapy+selenium+PhantomJS 内容:测试scrapy+PhantomJS 爬去内容:涉及到js加载更多的页面 原理:配置文件打开中间件+修改proces ...
- 从零开始开发一个简易的类vue-cli构建工具
代码地址:https://github.com/cheer4chai/webpack-learning 仿照vue-cli开发这个工具的目的是了解webpack的基本设置,以及vue-cli的工作原理 ...
- Windows程序设计学习笔记(四)自绘控件与贴图的实现
Windows系统提供大量的控件供我们使用,但是系统提供的控件样式都是统一的,不管什么东西看久了自然会厌烦,为了使界面更加美观,添加一些新的东西我们需要自己绘制控件. 控件在默认情况下并不进行自绘,如 ...
- 驱动开发入门——NTModel
上一篇博文中主要说明了驱动开发中基本的数据类型,认识这些数据类型算是驱动开发中的入门吧,这次主要说明驱动开发中最基本的模型--NTModel.介绍这个模型首先要了解R3层是如何通过应用层API进入到内 ...
- 在树莓派上编译安装golang环境
请看我在掘金的文章
- 编程范式:命令式编程(Imperative)、声明式编程(Declarative)和函数式编程(Functional)
主要的编程范式有三种:命令式编程,声明式编程和函数式编程. 命令式编程: 命令式编程的主要思想是关注计算机执行的步骤,即一步一步告诉计算机先做什么再做什么. 比如:如果你想在一个数字集合 collec ...
- 85、flask之wtforms
本篇导航: wtforms组件的使用 自定义From组件 一.wtforms组件的使用 1.flask中的wtforms WTForms是一个支持多个web框架的form组件,主要用于对用户请求数据进 ...
- 【转载】从头编写 asp.net core 2.0 web api 基础框架 (4) EF配置
Github源码地址:https://github.com/solenovex/Building-asp.net-core-2-web-api-starter-template-from-scratc ...
- [搬运] 写给 C# 开发人员的函数式编程
原文地址:http://www.dotnetcurry.com/csharp/1384/functional-programming-fsharp-for-csharp-developers 摘要:作 ...