首页 > 语言 > JavaScript > 正文

javascript实现回到顶部特效

2024-05-06 16:19:26
字体:
来源:转载
供稿:网友

当页面特别长的时候,用户想回到页面顶部,必须得滚动好几次滚动键才能回到顶部,如果在页面右下角有个“返回顶部”的按钮,用户点击一下,就可以回到顶部,对于用户来说,是一个比较好的体验。

HTML:

 

 
  1. <input id="btn1" type="button" value="回到顶部" /> 

CSS:

 

 
  1. #btn1{position:fixed;bottom:10px;right:10px;} 

JS:

 

 
  1. window.onload=funcition(){ 
  2. var oBtn=document.getElementById("btn"); 
  3. var timer=null
  4. //申明一个变量看是否为系统还是用户滚动 
  5. var sBys=true
  6. window.onscroll=funcition(){ 
  7. if(!sBys){ 
  8. clearInterval(timer); 
  9. sBys=false
  10. oBtn.onclick=funcition(){ 
  11. timer = setInterval(funcition(){ 
  12. //获取scrollTop 
  13. var scrollTop=document.documentElement.scrollTop||document.body.scrollTop; 
  14. //当点击按钮回到顶部时计算缓冲速度 
  15. var ispeed=Math.floor(-scrollTop/8); 
  16. if(scrollTop==0){ 
  17. clearInterval(timer) 
  18. sBys=true
  19. document.documentElement.scrollTop=document.body.scrollTop=scrollTop+ispeed; 
  20. },30) 

知识点:

1.计算速度(缓冲)向下取整

2.当scrollTop==0时需要清除定时器

3.需要判断是用户还是js操作滚动条,如果是用户操作就清除定时器

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选