Bootstrap导航栏如何使所选标签处于活动状态

4

我看过其他类似的帖子,但是我的无法运作。 我想让被点击的标签变为活动状态。

这是我的Bootstrap导航栏在HTML中的样式:

<div class="navbar navbar-default" role="navigation">
    <div class="container">
      <div class="navbar-header">
        <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
          <span class="sr-only">Toggle navigation</span>
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
          <span class="icon-bar"></span>
        </button>
        <a href="/">
          <img src="/static/images/logo.png" alt="Prime Solutions"/>
        </a>
      </div>

      <div class="navbar-collapse collapse">
        <ul class="nav navbar-nav">
          <li class="active"><a href="/"><strong>Acasa</strong></a></li>
          <li><a href="/software"><strong>Software</strong></a></li>
          <li><a href="/hardware"><strong>Hardware</strong></a></li>
          <li><a href="/about"><strong>Despre Noi</strong></a></li>
          <li><a href="/contact"><strong>Contact</strong></a></li>
          <li class="dropdown">
            <a href="#" class="dropdown-toggle" data-toggle="dropdown"><strong>Servicii</strong><b class="caret"></b></a>
            <ul class="dropdown-menu">
              <li><a href="/servicii/servicii">Servicii IT&C </a></li>
              <li><a href="/servicii/consultanta">Consultanta IT&C </a></li>
              <li class="divider"></li>
              <li class="dropdown-header">Parteneri</li>
              <li><a href="/parteneri">Partenerii nostri</a></li>
            </ul>
          </li>
        </ul>
        <ul class="nav navbar-nav navbar-right">
          <li><a class="btn btn-info" href="/noutati"><span id="news">Noutati</span></a></li>
        </ul>
      </div><!--/.nav-collapse -->
    </div>
  </div>

然而,它并没有起作用。它只是让我的Acasa选项卡保持活动状态。 我应该如何编写脚本?谢谢。

这是我<body>底部的样子:

<script src="/static/js/jquery.min.js"></script>
<script src="/static/js/bootstrap.min.js"></script>
<script src="/static/js/jquery-1.11.0.js"></script>
<script>
  ....... 
</script>

这是我尝试过的脚本:

<script>
  $('.nav.navbar-nav > li').on('click', function() {
    $(this).addClass('active');
    $(this).siblings().removeClass('active');
  });    
</script>

编辑:

好的,我找到了问题所在。jQuery是生效的,但是当我点击例如“软件”选项卡时,会重定向到 /software,因此由于重定向,“软件”选项卡并不会变为活动状态。这个导航栏出现在我的每个页面上。那么我该如何解决这个问题呢?


抱歉,我想写的是addClass。但仍然无法正常工作。 - Mihai Zamfir
2个回答

8

您可以使用:

$('.nav.navbar-nav > li').on('click', function(e) {
    $('.nav.navbar-nav > li').removeClass('active');
    $(this).addClass('active');
});    

Bootply演示


仍然不起作用...我已经编辑了我的帖子,以查看我如何声明我的脚本。 - Mihai Zamfir

2

在每个页面中使用此代码。

$(function() {
var loc = window.location.href;
   $(".navbar .navbar-nav > li").each(function() {
      if (loc.match('/software')) { // software is the name of the page/slug
        $(this).addClass("active"); 
        }
   });
});

如果你只有有限数量的页面,你可以使用'if else if条件。


谢谢。无论如何,我通过在服务器端编写逻辑来解决了这个问题。我太专注于使用jQuery解决方案,没有意识到我可以在服务器端解决这个问题。 - Mihai Zamfir
2
@Mihai Zamir,您能否请发布一下您在服务器端修复此问题的解决方案? - beeCoder

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接