基于Javascript实现返回顶部按钮


Posted in Javascript onFebruary 29, 2016

一个网页内容一多, 就会分屏显示数据, 如果屏目很多, 用户访问的数据已经到了页面的底部, 这时候返回到顶部也是需要一点时间. 这样对用户体验来说, 可能就稍微逊了一点. 所以页面数据多的网页, 现在都会用一个"返回顶部"按钮来快速跳转到网页的顶部.
那现在我们就来实现这么一个功能.

这个页面我们就不写什么数据, 直接就加入一个a标签来作为返回顶部的按钮, 并给他一个class名称:top.

<a href="#" class="top">顶部</a>

然后设置其样式表:

body {
  height: 3000px;
}

.top {
  position: absolute;
  top: 120px;
  display: inline-block;
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-decoration: none;
  text-align: center;
  background-color: #666666;
  color: #ffffff;
  right: 10px;
  transition: all 0.3s;
   visibility: hidden;
}
.top:hover {
  background-color: #ff3300;
}

这里body设定为3000的高度, 主要是让页面有滚动的效果. 按钮一般都是放在网页的右边靠下一点的位置. 这里我们通过position来设置.

我们还要分析一下, 当用户的访问的网页在页面的顶部时, 这个按钮肯定是不显示的. 所以我们这里用了visibility来控制按钮的显示与否.

界面很简单, 我们就先将就一下. 下面来分析JS的实现.

首先这个按钮是在整个网页的效果上, 因此监听滚动事件需要设置在整个窗口上. 因此,我们给window设置一个onscroll事件.

window.onscroll = function (e) {...}

在这个事件里我们来控制返回顶部按钮的上下位置, 和是否显示. 首先来完成上下位置的控制.

上下位置的控制, 我们肯定得计算scrollTop的高度, 以及网页单屏显示的高度. 当用户进入页面的时候, 我们默认给这个按钮放置在页面右中部位置. 这时候的计算是:

var n_half_height = window.screen.height / 2;

将这个值赋给按钮的top属性.

然后如果用户滚动的时候, 位置肯定是保持不变的, 这时候的计算应该是

var n_stop = e.target.scrollingElement.scrollTop; //获取scrollTop的高度
var n_top = n_stop + n_half_height;//得到位置

这是e 对象是onsroll里的参数event. 这里我使用的是谷歌浏览器.其他浏览器未测试. 如果需要兼容, 大家可以处理一下.
每滚动都得计算其高度, 所以这个应该是放入在onscroll事件中.然后,将这个值赋给按钮的top属性.

当然不要忘记一件事, 就是scrollTop为0的时候, 按钮不需要显示. 大于0的时候, 得让按钮显示. 前面讲过我们用visibility这个属性来控制的.这样代码就完整了.
Javascript完整代码

var ele_body = document.body;
var ele_top = document.getElementsByClassName("top")[0];
var n_half_height = window.screen.height / 2;
ele_top.style.top = n_half_height + "px";
window.onscroll = function (e) {
 var n_stop = e.target.scrollingElement.scrollTop;
 if (n_stop === 0 ) {
  ele_top.style.visibility = "hidden";
 }else {
  ele_top.style.visibility = "visible";
 }
 var n_top = n_stop + n_half_height ;
 ele_top.style.top = n_top + "px";
}

最后的效果展示:

基于Javascript实现返回顶部按钮

以上就是本文的全部内容,希望对大家的学习有所帮助。

Javascript 相关文章推荐
发现的以前不知道的函数
Sep 19 Javascript
asp.net+jquery滚动滚动条加载数据的下拉控件
Jun 25 Javascript
分享20多个很棒的jQuery 文件上传插件或教程
Sep 04 Javascript
商城常用滚动的焦点图效果代码简单实用
Mar 28 Javascript
Jquery实现列表(隔行换色,全选,鼠标滑过当前行)效果实例
Jun 09 Javascript
基于JS代码实现当鼠标悬停表格上显示这一格的全部内容
Jun 12 Javascript
form+iframe解决跨域上传文件的方法
Nov 18 Javascript
React学习笔记之事件处理(二)
Jul 02 Javascript
vue和better-scroll实现列表左右联动效果详解
Apr 29 Javascript
JS 设计模式之:单例模式定义与实现方法浅析
May 06 Javascript
vue tab切换,解决echartst图表宽度只有100px的问题
Jul 19 Javascript
vue组件讲解(is属性的用法)模板标签替换操作
Sep 04 Javascript
JavaScript实现斗地主游戏的思路
Feb 29 #Javascript
jQuery取消特定的click事件
Feb 29 #Javascript
JavaScript+CSS实现的可折叠二级菜单实例
Feb 29 #Javascript
JS三级可折叠菜单实现方法
Feb 29 #Javascript
精通JavaScript的this关键字
May 28 #Javascript
javascript正则表达式总结
Feb 29 #Javascript
javascript计时器编写过程与实现方法
Feb 29 #Javascript
You might like
第4章 数据处理-php数组的处理-郑阿奇
2011/07/04 PHP
PHP中的正则表达式函数介绍
2012/02/27 PHP
解析PHP的session过期设置
2013/06/29 PHP
php绘图中显示不出图片的原因及解决
2014/03/05 PHP
PHP实现简单用户登录界面
2019/10/23 PHP
JavaScript去除空格的几种方法
2006/10/03 Javascript
非常棒的10款jQuery 幻灯片插件
2011/06/14 Javascript
Jquery中使用setInterval和setTimeout的方法
2013/04/08 Javascript
jQuery下实现等待指定元素加载完毕(可改成纯js版)
2013/07/11 Javascript
js渐变显示渐变消失示例代码
2013/08/01 Javascript
extjs每个组件要设置唯一的ID否则会出错
2014/06/15 Javascript
js读写json文件实例代码
2014/10/21 Javascript
js实现对table动态添加、删除和更新的方法
2015/02/10 Javascript
Angularjs 创建可复用组件实例代码
2016/10/09 Javascript
使用开源工具制作网页验证码的方法
2016/10/17 Javascript
JavaScript计算值然后把值嵌入到html中的实现方法
2016/10/29 Javascript
微信小程序 密码输入(源码下载)
2017/06/27 Javascript
利用JS判断客户端类型你应该知道的四种方法
2017/12/22 Javascript
vue项目常用组件和框架结构介绍
2017/12/24 Javascript
使用layer弹窗和layui表单实现新增功能
2018/08/09 Javascript
[01:05:00]2018国际邀请赛 表演赛 Pain vs OpenAI
2018/08/24 DOTA
Python赋值语句后逗号的作用分析
2015/06/08 Python
Python基于回溯法子集树模板解决马踏棋盘问题示例
2017/09/11 Python
python3实现windows下同名进程监控
2018/06/21 Python
Python实现的登录验证系统完整案例【基于搭建的MVC框架】
2019/04/12 Python
python利用多种方式来统计词频(单词个数)
2019/05/27 Python
python在新的图片窗口显示图片(图像)的方法
2019/07/11 Python
Python3实现配置文件差异对比脚本
2019/11/18 Python
numpy 返回函数的上三角矩阵实例
2019/11/25 Python
在Python中等距取出一个数组其中n个数的实现方式
2019/11/27 Python
解决Tensorflow占用GPU显存问题
2020/02/03 Python
python之生成多层json结构的实现
2020/02/27 Python
通过代码简单了解django model序列化作用
2020/11/12 Python
领导班子整改方案和个人整改措施
2014/10/25 职场文书
2015年外联部工作总结
2015/04/03 职场文书
心理健康教育培训研修感言
2015/11/18 职场文书