练习前端技术学院的任务,需要实现“导航栏中的链接,随着鼠标悬浮的位置,相应的链接下出现红色线段”的效果(如图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动画效果自己理解的两种方法——练习笔记的更多相关文章

  1. /*去hover动画效果*/

    <!DOCTYPE html> /*去hover动画效果*/ <html lang="en"> <head> <meta charset= ...

  2. Activity透明/半透明效果的设置transparent(两种实现方法)

    两种方法实现Activity透明/半透明效果的设置,代码思路很有调理,感兴趣的朋友可以参考下,希望本文可以帮助到你   方法一:res/values文件夹下建立styles.xml: 复制代码代码如下 ...

  3. 两种方法使用js读写cookie实现一个底部广告浮层效果

    下面一个案例实现了js实现一个页面浮层并且使用两种方法使用js读写cookie:来实现用户关闭广告的显示状态: 读者可以将下面代码复制到一个html文件试试效果:html的pre标签未两种js实现的方 ...

  4. 利用 :before :after伪类实现鼠标悬浮动画效果

    1.最近在逛网站的时候,想找一下喜欢的鼠标悬浮效果,避免广告的嫌疑,直接放图了: 2.在实现的时候,如果在直接使用鼠标hover ,transform,进行过渡,不能达到想要的效果,因为同时只能触发一 ...

  5. css3 鼠标悬浮动画效果

    CSS3案例 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <ti ...

  6. JQuery简单动画效果的发生顺序和animate方法

    (1)在同一组元素上的效果 当在一个.animate()方法中以多个属性的方式应用时,是同时发生的. 当以方法连缀的形式应用时,是按顺序发生的(排队效果)---除非queue选项值为false. (2 ...

  7. 解决transition动画与display冲突的几种方法

    如demo(如果没有显示,请查看源地址http://jsfiddle.net/ihardcoder/HNduT/2/)所示,基本的效果是在点击“Translate”按钮后,蓝色区域透明度变为0,然后隐 ...

  8. android动画(3)layout动画,layoutChanged动画及算定义它,ListViewActivity的Layout动画(代码和xm配置两种实现l)

    1.layout切换动画 代码: 本示例是fragment切换.在它的oncreateView中 public class LayoutAnimationFrgmt extends Fragment ...

  9. jQuery 两种方法实现IE10以下浏览器的placeholder效果

    /* ** jQuery版本:jQuery-1.8.3.min.js ** 测试的浏览器:IE8,IETester下的IE6-IE9** Author:博客园小dee */ placeholder是H ...

随机推荐

  1. vue2 递归组件--树形

    递归组件,官方给的教程太简便了,根本看不出到底怎么用.于是自己查网摸索了一下,这儿只把核心思想写出来. 效果如下图,点击后打开二级菜单,再点击后打开三级. //js //引子//思想:当v-if='f ...

  2. python 模块:csv

    转自:http://www.cnblogs.com/sislcb/archive/2008/12/15/1355481.html (感谢整理) 举几个例子来介绍一下,Python 的 CSV模块的使用 ...

  3. amaze UI 笔记 - CSS

    导航添加依据 http://amazeui.org/css/  下面内容属学习笔记,如有理解偏差和错误请留言相告,感谢!* =(官网这块写的很详细) 一.基本样式 1.统一样式 说明了为什么使用Nor ...

  4. Ubuntu 16.04 LTS运行robo3t报错

    系统环境:Ubuntu 16.04 LTS. 安装robomongo Robo 3T,运行时报以下错误: jaxu@jaxu-ubuntu:/usr/local/share/robo3t--linux ...

  5. QMAKESPEC环境变量详解

    相关知识 要讲解QMAKESPEC环境变量的知识,先要了解如下知识 qmake .pro项目文件 makefile文件 1.qmake qmake是用来为不同的平台的开发项目创建Makefile的Tr ...

  6. Ubuntu 搭建简单的git server

    Git 可以使用四种主要的协议来传输资料:本地协议(Local),HTTP 协议,SSH(Secure Shell)协议及 Git 协议. 在此,我们将会讨论那些协议及哪些情形应该使用(或避免使用)他 ...

  7. golang其实也可以优先调度

    线上一个服务有个严重问题,处理消息数1k/s提升不上去,经过查看是阻塞在了一个新加的函数上,这个函数负责收集信息,送到一个channel上,再由某个函数处理,这个处理函数很简单,看不出任何问题,最大的 ...

  8. [转]C#异步的世界【上】

    阅读目录   APM EAP TAP 延伸思考 新进阶的程序员可能对async.await用得比较多,却对之前的异步了解甚少.本人就是此类,因此打算回顾学习下异步的进化史. 本文主要是回顾async异 ...

  9. 关于对JavaScript待于完善的一些知识点

    学习JavaScript也存在一段时间,以下是个人对JavaScript中抽象的知识点记录备案,将有待于后面逐个完善...... 1.JavaScript在内存中的体现(内存中栈堆与基本类型及引用类型 ...

  10. 用vue官方提供的模板vue-cli搭建一个helloWorld案例

    安装环境 安装node.js并配置环境变量 安装淘宝镜像,npm install -g cnpm --registry=https://registry.npm.taobao.org 安装webpac ...