需要帮助编辑JavaScript - 在单击其他链接时尝试使链接“活动”

时间:2013-08-11 01:50:37

标签: javascript jquery javascript-events

我需要帮助来帮助编辑以下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>

2 个答案:

答案 0 :(得分: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将获得有效课程,然后点击link2,然后link3将获得它等等....

答案 1 :(得分: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');
  });