当前位置: 首页 > news >正文

React滚动加载(无限滚动)功能实现

在用户滚动到接近页面底部时自动加载更多内容

   :可以将事件绑定在antd的Table组件中的onScroll中

   :也可以将事件绑定在外层的div的onScroll中

 

const handleScroll = (e) => {const { scrollTop, scrollHeight, clientHeight } = e.target;if (scrollTop + clientHeight >= scrollHeight - 50 && hasMore) {setPageNum((prevPage) => prevPage + 1);}
};
  • const { scrollTop, scrollHeight, clientHeight } = e.target;:

    • 这里通过对象解构,从 e.target(即触发滚动事件的元素)中获取了三个重要的属性:
      • scrollTop: 滚动条距离元素顶部的距离,即用户已经滚动了多少距离。
      • scrollHeight: 整个内容的高度,包括滚动在视窗外的部分,即元素的总高度。
      • clientHeight: 可视区域的高度,即用户能直接看到的部分的高度。
  • if (scrollTop + clientHeight >= scrollHeight - 50 && hasMore):

    • 这个条件判断是在检查用户是否滚动到了接近页面底部。具体解释如下:
      • scrollTop + clientHeight: 这是计算当前用户已经滚动的高度加上可视区域的高度,表示用户现在看到的最底部的高度。
      • scrollHeight - 50: 这是指整个内容高度减去 50 像素,表示接近底部(还剩 50 像素)的高度。
    • 判断逻辑: 如果用户滚动的总高度(scrollTop + clientHeight)大于或等于 scrollHeight - 50,说明用户已经接近页面底部,剩下的内容高度小于等于 50 像素时,且 hasMoretrue(表示还有更多内容可以加载),就会触发加载更多内容的逻辑。
  • setPageNum((prevPage) => prevPage + 1);:

    • 当上述条件满足时,执行这个函数,将当前的页码(pageNum)加 1,从而触发下一页数据的加载。

http://www.mrgr.cn/news/14410.html

相关文章:

  • 「个性化定制」引领美业新潮流|博弈美业SaaS系统探索未来美业的个性化革新
  • 恒电流间歇滴定法 (GITT) 测试教程
  • 高级MySQL数据库备份脚本
  • Flask-RESTFul 之 RESTFul 的响应处理
  • 离线环境玩转 Tauri
  • WPF- vs中的WPF应用项目模板 如何自己实现
  • 【前端面试基础】计算机网络、浏览器、操作系统
  • 大数据基础:离线与实时数仓区别和建设思路
  • AI模型:全能与专精的较量与未来潜力探讨
  • Vue vue/cli3 与 vue/cli4 v-for 和 v-if 一起使用冲突
  • IPv4地址和子网掩码
  • 2024最新FL Studio24.1.1.4285破解版中文安装包百度云网盘下载地址
  • python脚本自动备份华为交换机配置,Console重置密码,升级系统文件
  • 全局点云配准的新思考:没有良好初值时如何配准?
  • 少儿编程入门,Scratch、Python与C++,谁能成为孩子的首选语言?
  • AI绘画SD教程 | StableDiffusion像素风格绘制,轻松制作复古怀旧像素游戏画面风格,保姆级教程带你快速入门!
  • 153页PPT丨麦肯锡-咨询公司流程管理体系规划建设方法论
  • 基于SpringBoot的银行OA系统设计与实现
  • MC新手教程
  • 【SpringCloud Alibaba】(九)学习 Gateway 服务网关