I have wrote a script to detect when I reach the div element which is a navigation bar and then I change it’s css to position fixed and top 0 so it will be fixed to the top, the problem that it doesn’t do that, it acts like scroll to top and it jumps to the beginning of the screen. (it’s flickers)
Javascript
var currentScrollTop = 0;
var barMenuOriginalTopPos = $('#navigation').offset().top;
console.log('original:' + barMenuOriginalTopPos);
$(window).scroll(function() {
currentScrollTop = $(window).scrollTop();
console.log(currentScrollTop);
if(currentScrollTop >= barMenuOriginalTopPos && $('#navigation').hasClass('fixElementToTop') == false){
$('#navigation').addClass('fixElementToTop');
}
else if(currentScrollTop < barMenuOriginalTopPos && $('#navigation').hasClass('fixElementToTop') ){
$('#navigation').removeClass('fixElementToTop');
}
});
CSS
.fixElementToTop { position: fixed; top:0; z-index:100;}
Why
a css fixed bar on top of the screen
Review:
sorry i didn’t understand your initial question, here it goes, to avoid it flicking you should start the object with a fixed position, lets say:
the code: