<nav class="navigation-bar is-visible" data-nav-status="toggle">
<ul>
<li>Home</li>
<li>About</li>
<li>Services</li>
<li>Blog</li>
<li>Contact</li>
</ul>
</nav>
<section class="content"></section>
@import "compass/css3";
.navigation-bar {
background-color: GhostWhite;
border: 1px solid Gainsboro;
left: 0;
position: fixed;
right: 0;
top: 0;
z-index: 1000;
&.is-hidden {
opacity: 0;
transform: translate(0,-60px);
transition: transform .2s,background .3s,color .3s,opacity 0 .3s;
}
&.is-visible {
opacity: 1;
transform: translate(0,0);
transition: transform .2s,background .3s,color .3s;
}
ul {
list-style: none;
margin: 0;
padding: 0;
li {
display: inline-block;
padding: 1em;
}
}
}
.content {
min-height: 1200px;
}
View Compiled
$(document).ready(function(){
/** ===========================================
Hide / show the master navigation menu
============================================ */
// console.log('Window Height is: ' + $(window).height());
// console.log('Document Height is: ' + $(document).height());
console.log('Window Height is: ' + $(window).height());
console.log('Document Height is: ' + $(document).height());
var previousScroll = 0;
$(window).scroll(function(){
var currentScroll = $(this).scrollTop();
/*
If the current scroll position is greater than 0 (the top) AND the current scroll position is less than the document height minus the window height (the bottom) run the navigation if/else statement.
*/
if (currentScroll > 0 && currentScroll < $(document).height() - $(window).height()){
/*
If the current scroll is greater than the previous scroll (i.e we're scrolling down the page), hide the nav.
*/
if (currentScroll > previousScroll){
window.setTimeout(hideNav, 300);
/*
Else we are scrolling up (i.e the previous scroll is greater than the current scroll), so show the nav.
*/
} else {
window.setTimeout(showNav, 300);
}
/*
Set the previous scroll value equal to the current scroll.
*/
previousScroll = currentScroll;
}
});
function hideNav() {
$("[data-nav-status='toggle']").removeClass("is-visible").addClass("is-hidden");
}
function showNav() {
$("[data-nav-status='toggle']").removeClass("is-hidden").addClass("is-visible");
}
});
This Pen doesn't use any external CSS resources.