首页 > 代码库 > jquery版滑块导航栏

jquery版滑块导航栏

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<script src="http://www.mamicode.com/js/jquery-1.9.1.min.js" type="text/javascript" charset="utf-8"></script>
<title>小滑块导航栏</title>
</head>
<style type="text/css">
*{
margin: 0;
padding: 0;
}
.ulbox{
position: relative;
clear: both;
}
.nav{
height: 30px;
line-height: 30px;
}
.nav li{
list-style: none;
display: block;
float: left;
}
.nav li a{
display: block;
background-color: #000;
text-decoration: none;
color: #FFFFFF;
border-radius: 5px;
}
span{
position: absolute;
bottom: 0;
display: block;
height: 3px;
background-color: #FF6600;
}
</style>
<body>
<div class="ulbox">
<ul class="nav">
<li><a href="http://www.mamicode.com/#">导航一</a></li>
<li><a href="http://www.mamicode.com/#">导航二</a></li>
<li><a href="http://www.mamicode.com/#">导航三</a></li>
<li><a href="http://www.mamicode.com/#">导航四</a></li>
<li><a href="http://www.mamicode.com/#">导航五</a></li>
<li><a href="http://www.mamicode.com/#">导航六</a></li>
<li><a href="http://www.mamicode.com/#">导航七</a></li>
</ul>
<span class="line"></span>
</div>
</body>
<script type="text/javascript">
$(function(){
$(‘.ulbox .nav li‘).hover(function(){
var width=$(this).outerWidth(true);//获取当前li的宽度
var left=$(this).offset().left; //获取当前li的left值
$(".line").stop(true).animate({‘left‘:left,‘width‘:width},300);//为span标签添加滑动效果
},function(){
$(".line").animate({‘left‘:‘0‘,‘width‘:‘0‘},1000); //鼠标移出li时的动画
});
})
//.stop();停止当前动画,继续下一个动画,当是鼠标移动hover时 ,动画和显示不同步,显示达不到预期的结果。
//.stop(true);清除元素的所有动画,停止在当前状态
//.stop(false,true);让当前动画直接到达末状态 ,继续下一个动画
//.stop(true,true);清除元素的所有动画,让当前动画直接到达末状态
</script>
</html>

技术分享

 

jquery版滑块导航栏