想用jq判断滚动条滚到超过一定高度导航贴顶的怎么在谷歌浏览器会闪烁的?

roro5119 2018-07-04 08:18:51
我是这样写的

$(window).scroll(function () {
var pos = $(window).scrollTop();
if (pos > 69) {
$('#topnav').addClass('navbar-fixed-top');
}else{
$('#topnav').removeClass('navbar-fixed-top');
}
});
...全文
368 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
漠子凉 2018-07-15
  • 打赏
  • 举报
回复
闪烁的原因基本都是因为高度的监控问题,建议不要使用jq的scroll
举个例子
topnav的高度是100
你希望监控>100就贴顶
当大于100的时候,由于fix之后原nav的dom位置出现脱离意思是会导致scroll获取当前滚动条高度出现丢失nav高度,即当前滚动条高度不计算nav
所以当前你以为大于100,实际是0,然后触发addClass和removeClass都会出发scroll事件,不断的add,remove就达到了闪烁问题
你会发现只有滚动条高度大于200才不会闪烁,因为大于200的时候,fix类出现,当前的滚动条高度是200-100即大于100,所以没有再出现remove
天际的海浪 2018-07-04
  • 打赏
  • 举报
回复
只看js看不出什么问题,发一下完整代码

87,841

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧