我在使用 jQuery 制作粘性标题时遇到了一个特定问题。我尝试了网络上常用的片段,但我发现到处都是同样的错误。
在特定的文档高度(可滚动直到比调用粘性效果多一点),粘性标题在position: fixed
和之间跳转position: static
。
HTML:
<header>
<div id="not-sticky"></div>
<div id="sticky"></div>
</header>
<div id="content"> ...
jQuery:
var $sticky = $("#sticky");
var offset = $sticky.offset();
var stickyTop = offset.top;
var windowTop = $(window).scrollTop();
$(window).scroll(function() {
windowTop = $(window).scrollTop();
if (windowTop > stickyTop) {
$sticky.css({
position: 'fixed',
top: 0
});
}
else {
$sticky.css({
position: '',
top: ''
});
}
});
CSS:
header {
width: 100%;
}
#not-sticky {
padding: 50px 0;
width: 100%;
}
#sticky {
padding: 24px 0;
position: relative;
width: 100%;
z-index: 25;
}
#not-sticky
我还尝试了与 相同高度的边距底部#sticky
以保持恒定的文档高度,但发生了相同的跳跃粘性效果。
有什么想法可以解决这个问题吗?