jQuery弹性滑动导航菜单

制作方法
引入文件
<script src="js/jquery.min.js"></script>
HTML
<div id="nav"> <div class="nav-menu"> <a href="#">首页</a> <a href="#">了解我们</a> <a href="#">产品展示</a> <a href="#">服务报价</a> <a href="#">最新消息</a> <a href="#">联系方式</a> </div> <div class="nav-current"></div> </div>
CSS
#nav {
position: relative;
margin: 100px auto 0 auto;
width: 832px;
border-bottom: 2px #ddd solid;
_width: 835px;
}
#nav .nav-menu {
height: 50px;
}
#nav .nav-menu a {
float: left;
display: block;
padding: 0 40px;
height: 50px;
color: #666;
text-decoration: none;
font-size: 16px;
line-height: 50px;
}
#nav .nav-current {
position: absolute;
bottom: -2px;
overflow: hidden;
height: 2px;
background: #80b600;
}
JavaScript
$(function(){
(function(){
var $navcur = $(".nav-current");
var $nav = $("#nav");
var current = ".current";
var itemW = $nav.find(current).innerWidth(); //默认当前位置宽度
var defLeftW = $nav.find(current).position().left; //默认当前位置Left值
//添加默认下划线
$navcur.css({width:itemW,left:defLeftW});
//hover事件
$nav.find("a").hover(function(){
var index = $(this).index(); //获取滑过元素索引值
var leftW = $(this).position().left; //获取滑过元素Left值
var currentW = $nav.find("a").eq(index).innerWidth(); //获取滑过元素Width值
$navcur.stop().animate({
left: leftW,
width: currentW
},300);
},function(){
$navcur.stop().animate({
left: defLeftW,
width: itemW
},300);
});
})();
});
标签:jQuery