实现鼠标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 ...
随机推荐
- mac 安装mysql特种报错的对应解决方式
参考 :http://www.jianshu.com/p/776e72742c6e 原文废话太多了, 还是看我的好了. 配置环境变量 echo "export PATH=$PATH:/usr ...
- Flask 框架 简介
一.Flask介绍 Flask是一个基于Werkzeug,Jinja 2 轻量级的web开发框架, 使用Python开发, 上手简单. 二.安装Flask 三.第一个Flask程序 1.编写app.p ...
- vue2.0 项目build后资源文件报错404的解决方案
当vue项目build后,我们会看到css.js报错404的问题: 那我们就去找错误原因吧. 首先,查看build后的dist文件目录 可以看出,js.css在index.html的同级目录下: 然后 ...
- (译)Web是如何工作的:给Web开发新手的初级读物
原文地址:https://medium.freecodecamp.org/how-the-web-works-a-primer-for-newcomers-to-web-development-or- ...
- Check whether a remote server port is open on Linux
链接:https://www.pixelstech.net/article/1514049471-Check-whether-a-remote-server-port-is-open-on-Linux
- 【分块】BZOJ2821 作诗(Poetize)
2821: 作诗(Poetize) Time Limit: 50 Sec Memory Limit: 128 MBSubmit: 3265 Solved: 951[Submit][Status][ ...
- Python Tornado篇
Tornado既是一个web server,也是web framework.而它作为web server 采用的是asynchronous IO的网络模型,这是一种很高效的模型. Tornado 和现 ...
- 【知了堂学习心得】浅谈c3p0连接池和dbutils工具类的使用
1. C3P0概述 C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Spring等. 2. C3P ...
- Django_'utf-8' codec can't decode 问题解决
最近用vs2017新建django模板项目时,页面输入中文时导致编码错误,如下图: 几经排查,原来是对应的html文件保存的编码错误,重新用utf-8保存即可
- 【转】qlv文件如何转换成mp4 怎样把下载好的qlv格式视频转换成MP4格式
狸窝 复制 收藏 保存到桌面 快速找教程方案 反馈需求 社会主义核心价值观 客服QQ41442901 马上注册 升级VIP 对于视频文件之间的转换问题,我也已经是无力吐槽了,每个 ...