Резюме: я использую jquery для применения класса active
, который добавляет 'border-bottom'
к ссылке, которую пользователь просматривает в данный момент. Но отдельные ссылки border-bottom
отображаются на несколько пикселей выше navbar'
s border-bottom
. Это можно увидеть, развернув окно времени выполнения здесь:
https://jsfiddle.net/justinob8/Lopszd1e/4/
HTML:
<nav class="navbar navbar-expand-lg navbar-light ">
<a class="navbar-brand left-most-link" href="{% url 'index' %}">LOGO</a>
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarSupportedContent">
<ul class="navbar-nav ml-auto">
<li class="nav-item active">
<a class="nav-link right-link" href="#">Job Search<span class="sr-only">(current)</span></a>
</li>
<li class="nav-item">
<a class="nav-link right-link right-most-link" href="{% url 'employer_signup' %}">Post a Job<span class="sr-only">(current)</span></a>
</li>
</nav>
JQuery:
$(document).ready(function(){
$('li').click(function(){
$('li').removeClass('active');
$(this).addClass('active');
})
});
CSS:
nav{
border-bottom: 2px solid #eeeeee;
}
.right-link{
}
.right-most-link{
margin-right: 30px;
}
.left-most-link{
margin-left: 30px;
}
.active{
border-bottom: 1px solid black;
}