Jquery Add active class to main menu

2019-01-15 10:13发布

问题:

I'm trying to add dynamic active class to my main menu, but i can't able to achieve this,

My jquery is,

<script type="text/javascript">
$(document).ready(function() {
  $('#navi a[href^="/' + location.pathname.split("/")[1] + '"]').addClass('active');
});
</script>

My main menu is,

<ul id="navi">
  <li><a href="#">About MHG</a></li>
  <li><a href="#">Workout Programs</a></li>
  <li><a href="#">Fitness Tips</a></li>
  <li><a href="#">Contact Us</a></li>          
  <li><a href="#">Read Our Blog</a></li>
</ul>

回答1:

Try this

<ul id="navi">
    <li><a class="menu" href="#">About MHG</a></li>
    <li><a class="menu" href="#">Workout Programs</a></li>
    <li><a class="menu" href="#">Fitness Tips</a></li>
    <li><a class="menu" href="#">Contact Us</a></li>          
    <li><a class="menu" href="#">Read Our Blog</a></li>
  </ul>

jquery

$('a.menu').click(function(){
    $('a.menu').removeClass("active");
    $(this).addClass("active");
});

check this Fiddle http://jsfiddle.net/9nd4j/1/



回答2:

^^ same as above comment by Rory!!

, if you still need you can do

$("#navi a").live("click", function(){
  $("#navi a").removeClass("active");
  $(this).addClass("active")
});

If you have all the links pointing to a same page above solution works, as i see you going to traverse from one page to another this wont work.

Thanks



回答3:

Your description is not very clear. By active if you mean the list-item you are hovering on then it should be something like this:

$('a.menu').hover(

function () {
    $(this).addClass("active");
},

function () {
    $('a.menu').removeClass("active");
});