资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

js怎么实现返回顶部缓冲效果

这篇文章将为大家详细讲解有关js怎么实现返回顶部缓冲效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

创新互联凭借专业的设计团队扎实的技术支持、优质高效的服务意识和丰厚的资源优势,提供专业的网站策划、成都网站制作、成都网站建设、外贸营销网站建设、网站优化、软件开发、网站改版等服务,在成都十年的网站建设设计经验,为成都近千家中小型企业策划设计了网站。

运行原理

通过定时器30毫秒执行一次滚动条上升,每次上升的高度为当前高度的80%,这样就达到了上升缓冲的动画效果。

判断当滚动条高度超过一屏时,按钮显示,默认隐藏

知识要点

scrollTop//获取滚动条高度 需要写兼容
clientHeight//可视窗口高度 需要写兼容
setInterval//定时器
window.onscroll//滚动触发事件

完整代码





demo



返回顶部
 //在页面加载完后立即执行多个函数方案  function addloadEvent(func){   var oldonload=window.onload;   if(typeof window.onload !="function"){    window.onload=func;   }   else{    window.onload=function(){     if(oldonload){      oldonload();      }     func();    }   }  }  //在页面加载完后立即执行多个函数方案结束  addloadEvent(b);  function b(){   var gotop=document.getElementById("gotop");     var timer;   var tf=true;   //滚动触发   window.onscroll=function(){    //获取滚动条高度    var ostop=document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;    //获取窗口可视区域高度    //console.log(ostop)    var ch=document.documentElement.clientHeight||document.body.clientHeight;    //如果页面超过一屏高度按钮显示,否则隐藏    if(ostop>=ch){     gotop.style.display="block";    }else{     gotop.style.display="none";    }    //    if(!tf){     clearInterval(timer);        }     tf=false;   }   //点击触发   gotop.onclick=function(){    //创建定时器    timer=setInterval(function(){     //获取滚动条高度     var ostop=document.documentElement.scrollTop || window.pageYOffset || document.body.scrollTop;     //每次上升高度的20%     var speed=Math.ceil(ostop/5);     //每次上升当前高度的80% document.documentElement.scrollTop=document.body.scrollTop=ostop-speed;     //如果高度为0,清除定时器     if(ostop==0){      clearInterval(timer);     }      tf=true;    },30);      }  }

关于“js怎么实现返回顶部缓冲效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。


网站标题:js怎么实现返回顶部缓冲效果
链接分享:http://cdkjz.cn/article/jgggep.html
返回首页 了解更多建站资讯
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

业务热线:400-028-6601 / 大客户专线   成都:13518219792   座机:028-86922220