您当前的位置: 首页 > 

彭世瑜

暂无认证

  • 3浏览

    0关注

    2791博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

js监听页面或元素scroll事件,滚动到底部或顶部

彭世瑜 发布时间:2022-06-24 13:54:05 ,浏览量:3

在这里插入图片描述

基本原理:

1、滚动到底部
元素的滚动距离 + 元素的可视距离 == 元素的滚动条总距离

2、滚动到顶部
元素的滚动距离  == 0

监听页面滚动

DOCTYPE html>

  
    
    
    
    Scroll Demo
  

  
    
      .box {
        height: 5000px;
        text-align: center;
      }
    

    打开控制台查看

    
    

    
      // 滚动方向枚举值
      const DIRECTION_ENUM = {
        DOWN: "down",
        UP: "up",
      };

      // 距离顶部或底部的阈值
      const threshold = 20;

      // 记录前一个滚动位置
      let beforeScrollTop = 0;

      function handleScroll() {
        // 距顶部
        var scrollTop =
          document.documentElement.scrollTop || document.body.scrollTop;
        // 可视区高度
        var clientHeight =
          document.documentElement.clientHeight || document.body.clientHeight;
        // 滚动条总高度
        var scrollHeight =
          document.documentElement.scrollHeight || document.body.scrollHeight;

        // 打印数值
        console.table([
          {
            label: "距顶部",
            value: scrollTop,
          },
          {
            label: "可视区高度",
            value: clientHeight,
          },
          {
            label: "滚动条总高度",
            value: scrollHeight,
          },
          {
            label: "距顶部 + 可视区高度",
            value: scrollTop + clientHeight,
          },
        ]);

        // 确定滚动方向
        let direction = DIRECTION_ENUM.DOWN;
        if (beforeScrollTop > scrollTop) {
          direction = DIRECTION_ENUM.UP;
        }

        // 通过滚动方向判断是触底还是触顶
        if (direction == DIRECTION_ENUM.DOWN) {
          // 滚动触底
          if (scrollTop + clientHeight + threshold >= scrollHeight) {
            console.log("滚动触底");
          }
        } else {
          // 滚动到顶部
          if (scrollTop 
  打开控制台查看



  // 监听滚动
  let box = document.querySelector("#box");
  box.addEventListener("scroll", function (e) {
    let scrollTop = e.target.scrollTop;
    let clientHeight = e.target.clientHeight;
    let scrollHeight = e.target.scrollHeight;

    // 打印数值
    console.table([
      {
        label: "距顶部",
        value: scrollTop,
      },
      {
        label: "可视区高度",
        value: clientHeight,
      },
      {
        label: "滚动条总高度",
        value: scrollHeight,
      },
      {
        label: "距顶部 + 可视区高度",
        value: scrollTop + clientHeight,
      },
    ]);
  });

判断触底需要注意的点:

  • 滚动时需要区分向上滚动还是向下滚动
  • 滚动时可以设置一个阈值,并非完全触底或触顶才触发
  • 滚动事件需要做节流操作,以免短时间内被多次触发

在线Demo

  • 16.1、监听浏览器scroll滚动事件,触顶和触底
  • 16.2、监听元素scroll滚动事件,触顶和触底

参考 js 监听页面滚动到底部,监听可视区域滚动到底部

关注
打赏
1665367115
查看更多评论
立即登录/注册

微信扫码登录

0.0565s