原生js和jquery分别实现返回顶部的操作

// 我在做防抖节流的那部分例子的时候 很自然的想到了 浏览器返回顶部就是节流的一个好例子
如果不用节流的话 浏览器返回顶部会给人一种一卡一卡的感觉

<div>
	<button id="goTop">返回顶部</button>
</div>

// 样式中的 绝对定位 在父元素没有相对定位的情况下的话 是相对于浏览器的定位 这个主意了 不是相对于body

div{
	height: 2000px;
	border: 1px solid #f00;
}
button{
	position: fixed;
	bottom: 10px;
	right:10px;
}

第一种我们可以使用jquery的方式来实现

<script src="https://cdn.bootcss.com/jquery/3.4.1/jquery.min.js"></script>
var $bodyHtml = $('body, html');
//返回顶部
$('#goTop').click(function () {
	$bodyHtml.stop().animate({
		scrollTop: '0px'
	}, 1500);
});

第二种是用原生来写 用递归的方法

//创建变量
var scroll_Top = document.getElementById('goTop');
  
//用最常用的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);

当然你也可以用定时器中的 每秒让scrollTop -20px的方法来做
让window监听scroll事件 这样的话 就要用到节流了 不然那个按钮给人看起来一抖一抖的 体验不好
生活那么苦,那就笑着去面对,记得给自己吃颗糖!!!

发布了236 篇原创文章 · 获赞 80 · 访问量 2万+

猜你喜欢

转载自blog.csdn.net/yunchong_zhao/article/details/104996234
今日推荐