我有一个带有header
和nav
的简单页面。在窗口滚动时,我将 header
和 nav
设置为 fixed
位置。如果页面足够长可以滚动,一切顺利。如果页面处于特定高度,我会出现闪烁的情况。
var prev = 0;
var $window = $(window);
var nav = $('.context-nav');
var $navbar = $('.navbar');
$(window).scroll(function(e) {
var scrollTop = $window.scrollTop();
nav.toggleClass('fixed', scrollTop >= prev);
$navbar.toggleClass('fixed', scrollTop >= prev);
prev = scrollTop;
});
* {
box-sizing: border-box;
padding: 0;
margin: 0;
text-decoration: none;
}
html,
body {
font-size: 1rem;
background-image: linear-gradient(to right, #8ca986, #789a71);
}
.sp {
height: 700px;
}
header {
position: relative;
background: #fff;
height: 80px;
text-align: center;
box-shadow: 0 1px 15px rgba(0, 0, 0, 0.04), 0 1px 6px rgba(0, 0, 0, 0.04);
transition: all 500ms cubic-bezier(0.25, 0.46, 0.45, 0.94) 0s;
}
header.fixed {
position: fixed;
top: 0;
left: 0;
right: 0;
height: 60px;
}
.page-container {
padding: 2rem;
position: relative;
color: white;
}
.page-container .context-nav {
display: flex;
flex-direction: row;
color: white;
position: relative;
margin-bottom: 3rem;
padding: 1rem;
transition: all 0.4s ease;
}
.page-container .context-nav.fixed {
position: fixed;
left: 0;
right: 0;
top: 60px;
background-color: rgba(255, 255, 255, 0.08);
}
.page-container .context-nav .nav-item {
padding: 20px;
border: 1px solid white;
margin-right: 1rem;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<header class="navbar">
My header goes here
</header>
<div class="page-container">
<div class="context-nav">
<div class="nav-item">Item 1</div>
<div class="nav-item">Item 2</div>
<div class="nav-item">Item 3</div>
</div>
<h1 class="sp">Scroll me... </h1>
</div>
如果将类 .sp
的高度调整为小尺寸,就会看到问题。在我的示例中,我将其设置为 700px
。当我尝试滚动时,它会设置类但会直接将其删除,这会导致闪烁行为。当我将 .sp
类高度设置为 1200px
时,问题不存在。
有没有人有解决这个问题的想法?
最佳答案
发生闪烁是因为当您将元素设置为固定位置时,它会脱离流程并改变偏移量,如果您要寻找的是在滚动时显示 stickyElements,我建议您克隆该元素想在固定容器中显示为粘性,然后显示该容器,这样原始元素将保留在其原始位置并且不会导致内容跳转,我还注意到您正在使用计数器来显示和隐藏粘性元素,我除非你脑子里有不同的东西,否则思考是低效的。
这是我从你那里快速 fork 出来的一个代码笔来展示我的意思:
var $window = $(window);
var $stickyHeader = $('.stickyHeader');
var $nav = $('.context-nav');
var navOffset = $nav.offset().top;
var $navbar = $('.navbar');
var $newNavBar = $navbar.clone();
var $newNav = $nav.clone();
$stickyHeader.append($newNavBar);
$stickyHeader.append($newNav);
var timer;
$(window).scroll(function (e) {
if(timer) {
window.clearTimeout(timer);
}
timer = window.setTimeout(function(){
if($window.scrollTop() > navOffset) {
$stickyHeader.addClass('active');
}
else {
$stickyHeader.removeClass('active');
}
}, 100);
});
* {
box-sizing: border-box;
padding: 0;
margin: 0;
text-decoration: none;
}
html,
body {
font-size: 1rem;
background-image: linear-gradient(to right, #8ca986, #789a71);
}
.sp {
height: 700px;
}
header {
position: relative;
background: #fff;
height: 80px;
text-align: center;
box-shadow: 0 1px 15px rgba(0, 0, 0, 0.04), 0 1px 6px rgba(0, 0, 0, 0.04);
}
.active header {
width: 100%;
height: 60px;
}
.page-container {
padding: 2rem;
position: relative;
color: white;
}
.context-nav {
display: flex;
flex-direction: row;
color: white;
position: relative;
margin-bottom: 3rem;
padding: 1rem;
}
.active .context-nav {
left: 0;
right: 0;
background-color: rgba(255, 255, 255, 0.08);
}
.context-nav .nav-item {
padding: 20px;
border: 1px solid white;
margin-right: 1rem;
}
.stickyHeader {
width: 100%;
position: fixed;
height: 0;
overflow: hidden;
top: -140px;
transition: height 200ms ease, top 200ms ease;
}
.stickyHeader.active {
height: 140px;
top: 0;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<div class="stickyHeader">
</div>
<header class="navbar">
My header goes here
</header>
<div class="page-container">
<div class="context-nav">
<div class="nav-item">Item 1</div>
<div class="nav-item">Item 2</div>
<div class="nav-item">Item 3</div>
</div>
<h1 class="sp">Scroll me... </h1>
</div>
https://codepen.io/j-lastforone/pen/bzddmK
关于jquery - 滚动闪烁的固定位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54330740/