Static And Sticky Fixed Header Transition Misfunction
Solution 1:
For the first problem: part of the flash you are seeing is due to the fact that the sticky
header won't appear until the scroll position is > 100. Since the default
header has a height of 100px, when the scroll position is exatly 100px neither header is showing.
You can fix this by changing if ($(document).scrollTop() > 100)
to if ($(document).scrollTop() >= 100)
.
For the second issue of both divs showing at the same time, you'll need to stop the current animation before hiding the div. See below:
EDIT I've updated to address performance concerns using the techniques John Resig posted here: http://ejohn.org/blog/learning-from-twitter/ Note that this will introduce a 250ms delay, so there will be a slight delay when transitioning from the default header to the sticky header.
$(document).ready(function () {
var sticky = $('#sticky'),
defaultHeader = $('#default'),
header = $('#header')
defaultShowing = true,
didScroll = false;
$(window).on("scroll", function (e) {
didScroll = true;
});
window.setInterval(function () {
if(didScroll) {
didScroll = false;
var scrollTop = $(document).scrollTop();
if (defaultShowing && scrollTop >= 100) {
defaultShowing = false;
header.css('position', 'fixed');
defaultHeader.stop().hide();
sticky.fadeIn(1000);
} else if (!defaultShowing && scrollTop < 100) {
defaultShowing = true;
header.css('position', 'relative');
sticky.stop().hide();
defaultHeader.fadeIn(1000);
}
}
}, 250);
});
Solution 2:
Not sure what you mean by background, as all backgrounds in the CSS you show are solid.
Binding an event to scroll
with jQuery's .on()
can get slow on some browsers. Meaning that it won't fire as often as it should, delaying any function bound the the scroll event. Also, since you're taking 1000ms
to fade in the div, that will make the delay seem longer.
Post a Comment for "Static And Sticky Fixed Header Transition Misfunction"