JavaScript学习笔记—仿淘宝返回顶部

JavaScript学习笔记—仿淘宝返回顶部

分析:

  1. 带有动画的返回顶部
  2. 此时可以继续使用我们封装的动画函数
  3. 只需要把所有的left相关的值改为 跟 页面垂直滚动距离相关就可以了
  4. 页面滚动了多少,可以通过window.pageYOffset 得到
  5. 最后是页面滚动,使用window.scroll(x,y)

页面滚动

代码段:

续固定侧边栏代码

//3.当我们点击了返回顶部模块,就让窗口滚动到页面的最上方
  goBack.addEventListener('click',function(){
    //里面的x和y 不跟单位的 直接写数字即可
    //因为是窗口滚动 所以对象是window
    // window.scroll(0,0); 直接如此跳转太生硬 使用缓动动画
    animate(window,0);
  });
//动画函数
function animate(obj,target,callback){
 clearInterval(obj.timer);
obj.timer=setInterval(function(){
 var step=(target-window.pageYOffset)/10;
 step=step >0 ? Math.ceil(step):Math.floor(step);
 if (window.pageYOffset==target) {
 clearInterval(obj.timer);
 if (callback) {
  callback();
 }
}
//obj.style.left=obj.offsetLeft+step+'px';
// step+window.pageYOffset:页面当前被卷去的头部+步长=它最后要到达的距离
window.scroll(0,step+window.pageYOffset);
},15);
}

Learning from pink老师

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值