1

我需要帮助来编辑以下 JavaScript。

<script>
  $('.nav li a').on('click', function() {
    $(this).parent().parent().find('.active').removeClass('active');
    $(this).parent().addClass('active');
  });
</script>

==================================================== ==================

除了现有功能外,我还需要在单击“link1”时将“link2”变为“活动”。请参阅下面的 HTML。

<h1 class="brand"><a href="#link1">Brand</a></h1>
<ul class="nav">
  <li class="active"><a href="link2">One</a></li>
  <li><a href="link3">Two</a></li>
  <li><a href="link4">Three</a></li>
</ul>
4

2 回答 2

0

假设您应该在页面上只有一个活动元素,您可以执行类似的操作。

  $('.nav li a').on('click', function() {
    $('.active').removeClass('active');
    $(this).parent().addClass('active');
  });

如果没有,那么您可以closest像这样使用

  $('.nav li a').on('click', function() {
    $(this).closest('.active').removeClass('active');
    $(this).parent().addClass('active');
  });

根据您的评论,我认为这可行

  $('.nav li a').on('click', function() {
    $('active').removeClass('active');
    var link = $(this).attr('href'), // link1
        number = parseInt(link.substr(-1)), // 1
        newHref = link.slice(0, link.length - 1) + number++;
    $(newHref).addClass('active');

  });

因此,如果您单击link1然后将获得活动课程,然后link2单击将获得它,依此类推....link2link3

于 2013-08-11T02:43:47.580 回答
0

您可以使用以下代码。此处提供了一个jsFiddle示例。

  $('.nav li a').on('click', function (event) {
      event.preventDefault(); //Add this only if you want to stop the default link action.
      $(this).parent().siblings('li').removeClass('active');
      $(this).parent().addClass('active');
  });

  //The below is to make #link2 active whenever #link1 is clicked.
  $('.brand a').on('click', function () {
      $('.nav li:first').addClass('active');
      $('.nav li:first').siblings('li').removeClass('active');
  });
于 2013-08-11T03:01:27.403 回答