效果如下:
<DOCTYPE html> <html> <head> <script src="http://code.jquery.com/jquery-2.0.3.min.js"></script> <meta charset="UTF-8"> <style> .nav{height:40px; width: 100%;background: #E6E6E6;} .nav ul li{float: left;list-style: none;margin-right: 20px;line-height: 40px;} .nav ul li a{text-decoration: none; display: block;width: 60px; text-align: center;} .onNav{font-weight: bold;color:#fff; background: #ccc;} </style> </head> <body> <div class="nav"> <ul> <li><a href="#" class="onNav">首页</a></li> <li><a href="#">博客</a></li> <li><a href="#">论坛</a></li> <li><a href="#">关于</a></li> <li><a href="#">联系</a></li> </ul> </div> <script type="text/javascript"> $(".nav ul li a").click(function(){if($(this).has(".onNav")){ $(this).addClass("onNav").parent("li").siblings("li").find("a").removeClass("onNav");}}) </script> </body> </html>
js部分:
<script type="text/javascript"> $(".nav ul li a").click(function(){if($(this).has(".onNav")){ //找到a标签添加click事件,判断是否有背景存在 $(this).addClass("onNav").parent("li").siblings("li").find("a").removeClass("onNav");}}) //添加类并移除已有的类 </script>
上面是一种方法,以下是另外一种:
<script type="text/javascript">
$(".nav ul li a").click(function(){ //找到a标签并添加click事件 var inx = $(this).parent("li").index(); //定义变量inx,返回这个元素在同辈中的索引位置 $(".nav ul li").find("a").removeClass("on_nav"); //移除已有的类 $(".nav ul li").eq(inx).find("a").addClass("on_nav"); //获取点击元素并添加类
</script>