最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 实现一个简单的“返回顶部”按钮

    正文概述 掘金(走十里路看你傻笑)   2021-06-14   387

    这是我参与更文挑战的第 13 天,活动详情查看:更文挑战


    虽然没啥好说的,但简单介绍一下吧

    返回页面顶部的按钮允许用户快速返回页面顶部。当页面包含超过一页内容,甚至说有无限加载功能时

    创建“返回顶部”按钮

    首先,我们先选中“返回顶部”按钮。可以先假设页面中已经有这个按钮了。

    var scrollToTopBtn = document.getElementById("scrollToTopBtn")
    

    然后,选中整个文档。通过文档元素,可以获取到距离顶部的高度。这里将其设置为 rootElement

    var rootElement = document.documentElement
    

    我们将在按钮上添加一个点击事件监听器。当点击按钮时执行 scrollToTop 方法:

    function scrollToTop {
      // 滚动到顶部
    }
    scrollToTopBtn.addEventListener("click", scrollToTop)
    

    然后,这是滚动到顶部的方法:

    function scrollToTop() {
      // 滚动到顶部
      rootElement.scrollTo({
        top: 0,
        behavior: "smooth" //动画效果
      })
    }
    

    还记得一开始提到的“返回顶部”按钮吗?现在应该创建出来了:

    <footer>
      <!-- Scroll to top button -->
      <button id="scrollToTopBtn">返回顶部</button>
    </footer>
    

    这样我们已经达到最简单的效果了。一个简单的按钮创建成功。

    但这个按钮现在是始终在界面上的,我们期望只有在需要的时候才显示这个按钮。

    为了满足这个需求,有两种解决方案:

    • 使用 scroll 事件监听,当滚动到距离顶部一个合适的距离时才展现
    • 使用 IntersectionObserver ,当检测到与视口相交时展现

    下面分别介绍两种方式:

    检测滚动位置

    可以监听 scroll 事件来控制“返回顶部”按钮的显示和隐藏

    function handleScroll() {}
    
    document.addEventListener("scroll", handleScroll)
    

    每次用户滚动时,handleScroll方法都会被调用。

    现在我们需要滚动区间的总距离,这样通过当前距离 / 总距离 得到一个比率,根据比率确定显示隐藏。

    scrollHeight 给出元素的高度,包括由于溢出而无法看到的部分。 clientHeight 以像素表示元素的内部高度,这是可见部分的高度。

    因此,滚动总高度为 scrollHeightclientHeight 的差值

    var scrollTotal = rootElement.scrollHeight - rootElement.clientHeight
    

    通过将当前滚动的距离除以滚动总高度,可以得到一个 0-1 之间的比值。使用这个比值切换按钮显示和隐藏效果。

    下面的例子中,比值设置为 0.8,表示滚动到距离顶部 80% 的位置显示或隐藏

    var rootElement = document.documentElement
    
    function handleScroll() {
      var scrollTotal = rootElement.scrollHeight - rootElement.clientHeight
      if ((rootElement.scrollTop / scrollTotal ) > 0.80 ) {
        // 显示按钮
      } else {
        // 隐藏按钮
      }
    }
    
    document.addEventListener("scroll", handleScroll)
    

    可以设置合适的样式保证按钮显示隐藏。具体样式这里不表。

    基于 onscroll 的监听虽然比较好理解,但监听这个事件对性能的压力较大。某些浏览器对这个事件进行了优化处理,可能会导致无法即时响应(比如移动端的 safari)。

    使用 IntersectionObserver 替换 onscroll 监听

    首先创建一个新的监听实例。这个监听实例允许符合条件时执行对应的回调事件

    let observer = new IntersectionObserver(callback);
    

    设定回调事件:

    function callback(entries, observer) {
      // 回调会返回一个元素数组,即便你选择监听一个元素。
      entries.forEach(entry => {
        if (entry.isIntersecting) {
          // 显示按钮
        } else {
          // 隐藏按钮
        }
      });
    }
    

    最后,选择“返回顶部”按钮为被监听的元素

    observer.observe(target);
    

    起源地下载网 » 实现一个简单的“返回顶部”按钮

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元