I'm trying to achieve a slide-in menu with a button toggle (toggleClass). I am not sure though how I can add the animation. I tried to let it slide in from the top (animation name in a.css is slideInDown)
This is my demo, so you can see what I have.
HTML
<!-- ========== Navigation ========== -->
<a type="button" class="btn btn-blue nav-btn"><i class="fa fa-bars"></i></a>
<div class="navbar navbar-fixed-top closed" role="navigation" id="top-header">
<div class="container">
<ul class="nav navbar-nav">
<li class="active"><a class="scroll" href="#home">Home</a></li>
<li><a class="scroll" href="#services">Services</a></li>
<li><a class="scroll" href="#works">Works</a></li>
<li><a class="scroll" href="#about">About</a></li>
<li><a class="scroll" href="#timeline">Timeline</a></li>
<li><a class="scroll" href="#blog">Blog</a></li>
<li><a class="scroll" href="#contact">Contact</a></li>
</ul>
</div>
</div>
<!-- ========== /Navigation ========== -->
JS
// Open/close menu when button is clicked
$(".nav-btn").click(function () {
$(".navbar").toggleClass('closed open');
return true;
});
CSS Snippet
.open {
display:block;
visibility:visible;
}
.closed {
display:none;
visibility:hidden;
}
(This is animate.css which I'm using in general for the site)
EDIT: based on the answer from @stewbydoo (thank you so much!) I came up with:
// Open/close menu when button is clicked
$(".nav-btn").click(function () {
if($(".navbar").hasClass("closed")){
$(".navbar").removeClass("closed");
$(".navbar").addClass("animated slideInDown");
}else{
$(".navbar").removeClass("animated slideInDown");
$(".navbar").addClass("closed");
}
});
Which looks a little messy, but is sliding down just fine. Now I need to figure out how to let it slide up (nicely) again :)