【发布时间】:2017-01-04 00:58:04
【问题描述】:
到目前为止,我在网上找到的所有内容都与航点上的褪色或滚动的 x 距离有关。
但是,我需要我的导航栏在移动一定距离后淡出 无论页面上滚动的开始位置。
到目前为止,我已经让它仅在滚动动作上淡入淡出。我在这里和在我发布代码的 codepen 上偶然发现了几种不同的方法。到目前为止,这似乎是最好的方法,尽管在移动设备上感觉有问题。我在某处读过这种代码,但不应该用于移动平台。
为了在这里更客观,我希望导航栏在向下滚动屏幕 1/3 的距离时淡出,无论起点是什么。
以下是 JS 代码,感谢成员 Tushar。
完整的工作代码可以在这里找到codepen。
var lastScrollTop = 0, delta = 5;
$(window).scroll(function(event){
var st = $(this).scrollTop();
if(Math.abs(lastScrollTop - st) <= delta)
return;
if (st > lastScrollTop){
// downscroll code
$(".navbar").fadeOut()
} else {
// upscroll code
$(".navbar").fadeIn();
}
lastScrollTop = st;
});
【问题讨论】:
标签: javascript jquery twitter-bootstrap css-animations