Rehan
Rehan

Reputation: 4013

Changing the color of active nav-item

I have a navbar designed in Bootstrap. I am trying to make it a different color when the class of the nav-item is set to active.

However I am not able to do so. When I set the background the background color is changing, but when I use color the color is not changing. Note that I'm using Bootstrap v4.

$(document).ready(function() {
  "use strict";

  $('ul.navbar-nav > li').click(function(e) {
    e.preventDefault();
    $('ul.navbar-nav > li').removeClass('active');
    $(this).addClass('active');
  });
});
.navbar-toggler:focus {
  outline: 0;
}
.navbar-nav > .active {
  color: aqua!important;  **// THIS DOES NOT WORK**
  background-color: chartreuse; **//THIS WORKS**
}
.nav-item > a:hover {
  color: aqua!important;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<nav class="navbar navbar-light animated fadeInLeft" style="background-color: #C0C0C0 ;">
  <button class="navbar-toggler navbar-toggler-left" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="#navbarNav" aria-expanded="false" aria-label="Toggle navigation"><span class="lines"></span><span class="lines"></span><span class="lines"></span>
  </button>
  <h1 class="navbar-brand mb-0 move-header ">NavBrand</h1>
  <div class="collapse animated fadeInLeft" id="navbarNav">
    <ul class="navbar-nav">
      <li class="nav-item active">
        <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="#">Features</a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="#">Pricing</a>
      </li>
      <li class="nav-item">
        <a class="nav-link disabled" href="#">Disabled</a>
      </li>
    </ul>
  </div>
</nav>

Upvotes: 6

Views: 75918

Answers (5)

Guilherme Gosse
Guilherme Gosse

Reputation: 1

.nav-link:focus {
  color: aqua !important;
}

Upvotes: 0

udorb b
udorb b

Reputation: 139

.nav-bar .nav-link.active {
  background-color: #color;
  !important;
}

Upvotes: 0

Mukesh Ram
Mukesh Ram

Reputation: 6328

Try using adding color CSS on the a tag:

.navbar-nav > .active  a{
    color : aqua;
}

.navbar-toggler:focus {
  outline: 0;
}

.navbar-nav>.active {
  color: aqua!important;
  ** // THIS DOES NOT WORK**
  background-color: chartreuse;
  ** //THIS WORKS**
}

.navbar-nav>.active a {
  color: aqua
}

.nav-item>a:hover {
  color: aqua!important;
}

ul li {
  list-style: none;
  margin: 10px
}
<link href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet" />
<nav class="navbar navbar-light animated fadeInLeft" style="background-color: #C0C0C0 ;">
  <button class="navbar-toggler navbar-toggler-left" type="button" data-toggle="collapse" data-target="#navbarNav" aria-controls="#navbarNav" aria-expanded="false" aria-label="Toggle navigation"><span class="lines"></span><span class="lines"></span><span class="lines"></span></button>
  <h1 class="navbar-brand mb-0 move-header ">NavBrand</h1>
  <div class="collapse1 animated fadeInLeft" id="navbarNav">
    <ul class="navbar-nav">
      <li class="nav-item active"> <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a> </li>
      <li class="nav-item"> <a class="nav-link" href="#">Features</a> </li>
      <li class="nav-item"> <a class="nav-link" href="#">Pricing</a> </li>
      <li class="nav-item"> <a class="nav-link disabled" href="#">Disabled</a> </li>
    </ul>
  </div>
</nav>

Upvotes: 1

Gmoney Mozart
Gmoney Mozart

Reputation: 97

.active a{
  color: red !important;
}

this should work for over-riding the custom bootstrap 4 theme.

Upvotes: -1

Rory McCrossan
Rory McCrossan

Reputation: 337560

The issue is because the .nav-item > a:hover is more specific than .navbar-nav > .active. To fix this, remove the !important operator (as you should avoid it at all costs) and make the rule you want to override more specific.

.navbar-nav > .active > a {
  color: aqua;
  background-color: chartreuse;    
}
.nav-item > a:hover {
  color: aqua;
}

$(document).ready(function() {
  "use strict";

  $('ul.navbar-nav > li').click(function(e) {
    e.preventDefault();
    $('ul.navbar-nav > li').removeClass('active');
    $(this).addClass('active');
  });
});
.navbar-nav > .active > a {
  color: aqua;
  background-color: chartreuse;
}
.nav-item > a:hover {
  color: aqua;
}
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.0.0-alpha.6/css/bootstrap.css" />
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://npmcdn.com/[email protected]/dist/js/tether.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.0.0-alpha.6/js/bootstrap.min.js"></script>

<ul class="navbar-nav">
  <li class="nav-item active">
    <a class="nav-link" href="#">Home <span class="sr-only">(current)</span></a> 
  </li>
  <li class="nav-item">
    <a class="nav-link" href="#">Features</a> 
  </li>
  <li class="nav-item">
    <a class="nav-link" href="#">Pricing</a> 
  </li>
  <li class="nav-item">
    <a class="nav-link disabled" href="#">Disabled</a> 
  </li>
</ul>

Upvotes: 6

Related Questions