js,jquery吸顶实现与问题解决

一.原生js实现吸顶效果

  • scrollTop属性:元素的最顶部到窗口顶边的距离。即是滚动条滚动的距离
  • offsetTop属性:元素到其父层顶部的距离。不能对其进行赋值。设置元素到页面顶部的距离请用style.top属性。
var navBar = document.getElementById("#navBar"),
    navToTop = navBar.offsetTop();
document.onscroll = function () {
   //获取当前滚动距离
   var scrollDistance = document.body.scrollTop || document.documentElement.scrollTop;
   //如果滚动距离大于发票号条距顶部的距离,给发票号条设置fix
   if (scrollDistance  > navToTop + 80) {
       navBar.className = "common fix";       
    } else {
       navBar.className = "common";
    }
}
//css代码
//fix{position: absolute;top:0;left:0}

 二.jquery实现吸顶效果

  • offset()方法:获取匹配元素在当前视口的相对偏移。返回的对象包含两个整型属性:top 和 left,以像素计。此方法只对可见元素有效。
  • scrollTop()方法:获取匹配元素相对滚动条顶部的偏移。此方法对可见和隐藏元素均有效。
  • addClass()方法:添加样式类
  • removeClass()方法:移除样式类
  • 坚挺scroll事件
var navBar = $("#navbar");
var navToTop = navBar.offset().top;
$(document).on('scroll',function(){
    var scrollDistance = $(document).scrollTop();
    if(scrollDistance > navToTop){
        navBar.addClass("fix");
    }else{
        navBar.removeClass("fix");
    }
})

三.问题

情景:要吸顶的元素上面有其他有高度元素,

1.原生js出现问题,吸顶元素自身跳动,offsetTop是相对父层顶部,所以要scrollDistance>navToTop + 上方元素的高度

2.jquery不会出现问题,offset()是相对于视口的。

情景:吸顶一瞬间,要吸顶元素下方跳动

原因:吸顶元素设置成fixed,脱离文档流,所以下方元素跳动

解决办法:

(1)设置占位框,默认display:none,滚动到距离时display:block;

(2)给吸顶元素添加包含框,并设置高度。

 

转载于:https://my.oschina.net/wyc1219/blog/1506093

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值