利用scrolltop实现回到顶部功能遇到的坑

实现一个简单的点击回到顶部 ,  就直接写了一个点击事件

document.body.scrollTop = 0;

测试发现在谷歌浏览器没效果 , 在火狐浏览器可以

然后就查询了一下发现谷歌是不支持body元素获取scrollTop 属性的,

谷歌下需要用到document.documentElement.scrollTop,

在苹果的safari浏览器下只能用window.pageYOffset来替代scrollTop

然后就衍生出了下面这种兼容写法:

function getScrollTop(){ 

var scrollTop=document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;  

return scrollTop; 

}; 

function setScrollTop(num){ 

document.documentElement.scrollTop = num;   

window.pageYOffset = num;  

document.body.scrollTop = num;   

};

在jQuery下也有同样的兼容问题 ,

$('body').scrollTop();在IE火狐下有效,$('html').scrollTop();在谷歌和Safari下有效,

最终版本$('html,body').animate({'scrollTop':0},300);


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值