这次给大家一起分享的是:纯CSS样式写出的导航栏选中下标有下划线以及鼠标移开下标的下划线就回到刚刚的位置上的效果。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>test</title>
<link rel="stylesheet" type="text/css" href="css/common.css">
</head>
<body>
<div class="header">
<div class="logo">
<img src="images/logo.png" alt="logo">
</div>
<ul>
<li><a href="#">首页</a></li>
<li><a href="#">java</a></li>
<li><a href="#">php</a></li>
<li><a href="#">html</a></li>
<li><a href="#">javascript</a></li>
<li class="move"> </li>
</ul>
</div>
</body>
</html>
body{
padding: 0px;
margin: 0px;
min-width: 1200px;
}
.header {
height: 56px;
width: 100%;
}
div.logo {
float: left;
margin: 5px 50px;
width: 90px;
}
div.logo img {
width: 100%;
height: 100%;
overflow: hidden;
}
ul {
list-style-type: none;
padding: 0px;
float: right;
position: relative;/*子元素absol*/
}
ul li {
width: 110px;
height: 56px;
text-align: center;
float: left;
}
ul li a {
color: #848789;
text-decoration: none;
line-height: 56px;
}
ul a:hover{
color: red;
}
.move{
height: 4px;
width: 110px;
border-top: 4px solid red;/*只需要将上边显示出来*/
position: absolute;
left: 0;
top: 52px;
transition: left .2s ease-in-out 0s;/*包含四个过度属性:执行变换属性、执行时间、速率、延迟*/
-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{ /*li元素的父元素的第一个子元素,当鼠标停留其上时,move元素的left属性改变*/
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;
}
效果如下:
![]()
![]()
![]()
PS:1.移动,其实就是transition属性;2.使用超链接下面出现下划线,用的是:hover伪类;即最后几行css代码。