问题描述
我正在尝试在引导程序上使用此Smart Scroll https://bootstrap-menu.com/detail-smart-hide.html,该功能在桌面设备上可以正常使用,但在移动设备上,向下滚动然后返回顶部时,导航栏会出现故障。回到顶部后,导航栏将再次隐藏。我已经尝试过Bootstrap 4 Smart Scroll的建议,但是没有用。
js
if ($('.smart-scroll').length > 0) { // check if element exists
var last_scroll_top = 0;
$(window).scroll(function() {
var scroll_top = $(window).scrollTop();
if(scroll_top > 1) { $(".smart-scroll").addClass("scrolled-up");} else {$(".smart-scroll").removeClass("scrolled-up");}
if(scroll_top < last_scroll_top) {
$('.smart-scroll').removeClass('scrolled-down').addClass('scrolled-up');
}
else {
$('.smart-scroll').removeClass('scrolled-up').addClass('scrolled-down');
}
last_scroll_top = scroll_top;
});
}
css
.smart-scroll{
position: fixed !important;
right: 0;
left: 0;
z-index: 1030!important;
transition: all 0.3s ease-in-out;
}
.scrolled-down{
transform:translateY(-100%) !important;
}
.scrolled-up{
transform:translateY(0) !important;
}
我的模板导航栏正在使用自定义JS将导航栏固定在顶部,而不是固定在顶部。
function loadWindowEvents() {
$(window)
.on("scroll",function() {
loadSkills();
});
$(window)
.on('scroll',function() {
if ($(window)
.scrollTop() >= 100) {
$('.menu-wrap')
.addClass('fixed');
} else {
$('.menu-wrap')
.removeClass('fixed');
}
});
}
要测试原始代码,此故障在代码本身中,有人可以帮助解决此问题并在iPhone Safari中对其进行测试吗?
我发现以下JS有人发布了一些JS,如果有人可以帮助我将其应用到我的代码中,他们将使其正常工作。
window.location.hash.startsWith("#nav") && (window.location.hash = "",a());
let c = 0;
window.addEventListener("scroll",() => {
const t = Math.abs(parseInt(document.documentElement.getBoundingClientRect().top));
if (t <= n + 1 || t <= i.getBoundingClientRect().top + 1) return e.classList.remove("is-scrolled"),e.classList.remove("is-pinned"),void e.classList.remove("is-transition-enabled");
t > n + 2 * e.offsetHeight && (e.classList.add("is-scrolled"),e.classList.contains("is-transition-enabled") || g(600).then(() => e.classList.add("is-transition-enabled"))),Math.abs(t - c) < 5 || (t < c ? e.classList.add("is-pinned") : e.classList.remove("is-pinned"),c = t)
}),t.addEventListener("click",async t => {
t.preventDefault(),e.classList.contains("is-open") ? h() : a()
});
解决方法
来自 bootstrap 4 smartscroll 的答案是正确的。
只是 renderer.debug.checkShaderErrors = true
最后一行的类型错误
.js
应该是 -> lastScrollTop = st;