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,从而触发下一页数据的加载。
  • 5
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在TypeScript中实现一个无限滚动的菜单通常涉及到两个关键部分:内容分页和滚动事件处理。这里是一个简单的示例,假设我们有一个数组作为菜单的数据源,并且使用`IntersectionObserver`来进行滚动检测: ```typescript import { useEffect, useRef, IntersectionObserver } from 'react'; interface MenuItem { id: number; title: string; } const InfiniteMenu = () => { const menuItems = ['item1', 'item2', ...]; // 你的实际数据源 const menuRef = useRef<HTMLDivElement>(null); const observer = new IntersectionObserver((entries) => { entries.forEach((entry) => { if (entry.isIntersecting && !entry.rootIsVisible) { // 当元素进入视口时,加载更多数据 loadMoreItems(); } }); }); useEffect(() => { if (menuRef.current) { observer.observe(menuRef.current); return () => { observer.unobserve(menuRef.current); }; } return undefined; }, [observer]); const loadMoreItems = () => { // 这里你需要根据实际需求向服务器请求新的数据,并添加到现有列表中 // 假设新数据为 `newItems` menuItems.push(...newItems); }; return ( <div ref={menuRef}> {/* 渲染菜单项 */} {menuItems.map((item, index) => ( <li key={index}>{item}</li> ))} {/* 添加滚动到底部的占位符,触发加载更多 */} {loadMoreIndicator && ( <div ref={(c) => loadMoreIndicator.current = c} style={{ height: '100px' }} /> )} </div> ); }; export default InfiniteMenu; ``` 在这个例子中,我们创建了一个`IntersectionObserver`实例来监听`menuRef`元素的可见性。当用户滚动到菜单底部时(即元素不再在视口中),`loadMoreItems`会被调用来获取并添加更多的菜单项。 注意,这只是一个基础的示例,实际应用可能还需要考虑性能优化、错误处理以及滚动区域的高度动态调整等问题。同时,这只是一个React组件,如果你的项目不是React,那么可能需要相应地调整API和语法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值