详解原生JS回到顶部

第一次知道可以用超链接(锚点)实现回到顶部的时候我是很震惊的,想着原来可以这么简单啊!但是作为一个正在学习JS的小白,不能就这么轻易止步,所以查资料自己整了一个JS返回顶部

HTML代码:

?
1
2
3
4
5
< div class = "container" >
     < p >你好哇</ p >
     ...
</ div >
< div id = "top" >回到顶部</ div >

CSS代码:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
.container{
     border : 1px solid black ;
}
# top {  
     position : fixed ;
     padding : 10px ;
     width : 20px ;
     border : 1px solid black ;
     box-shadow: 0 0 2px #333 ;
     right : 20px ;
     bottom : 20px ;
}
# top :hover{
     cursor : pointer ;
}

JS代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
//创建变量
var scroll_Top = document.getElementById( 'top' );
  
//用最常用的scrollTop属性实现
var timer = null ;
function scrollTop(){
     // 取消一个通过调用requestAnimationFrame()方法添加到计划中的动画帧请求.
     cancelAnimationFrame(timer);
     /* requestAnimationFrame 会把每一帧中的所有DOM操作集中起来,
     在一次重绘或回流中就完成,并且重绘或回流的时间间隔紧紧跟随浏览器的刷新频率
     一般来说,这个频率为每秒60帧。 */
     timer = requestAnimationFrame( function sTop(){
         var top = document.body.scrollTop || document.documentElement.scrollTop;
         if (top > 0){
       //使用定时器,将scrollTop的值每次减少20(自行设置),直到减少到0,则滚动完毕
             document.body.scrollTop = document.documentElement.scrollTop = top - 20;
             timer = requestAnimationFrame(sTop);
         } else {
             cancelAnimationFrame(timer);
         }
     });
}
scroll_Top.addEventListener( 'click' , scrollTop, false );

转载于:https://www.cnblogs.com/good10000/p/10605834.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值