解决 InfiniteScroll 滚动 BUG

在之前实现滚动加载方案有

方案一:官方 Ant Design 方案

复制代码
<div
      id="scrollableDiv"
      style={{
        height: 400,
        overflow: 'auto',
        padding: '0 16px',
        border: '1px solid rgba(140, 140, 140, 0.35)',
      }}
    >
<InfiniteScroll
                            dataLength={modelDesc.length}
                            next={loadMore}
                            hasMore={hasMore}
                            loader={<div className={styles.loading}>加载中...</div>}
                            endMessage={<div style={{ textAlign: 'center' }}>已加载全部数据</div>}
                            scrollableTarget="scrollContainer"
                        >
</div>

通过在外层嵌套标签<div>并添加id="scrollableDiv"属性,InfiniteScroll 中直接绑定这个属性scrollableTarget="scrollableDiv"实现滚动加载。

方案二:InfiniteScroll 直接添加 height 属性

与外层标签<div> scrollableDiv绑定失效,导致无法实现滚动加载,进入官方文档排查之后直接在

InfiniteScroll 标签中添加 height 属性,height={700},不使用外层标签 <div> ,以此实现滚动加载。

复制代码
<InfiniteScroll
          dataLength={allMessages.length}
          next={handleOnLoad}
          hasMore={hasMore}
          endMessage={
            (() => {
              return allMessages.length === 0 ? null : (
                <div style={{ textAlign: 'center' }}>已加载全部数据</div>
              );
            })()
          }
          height='calc(100vh - 200px)'
          className={styles.scrollContainer}
        >

方案三:通过动态计算

前两者实现起来都有问题的情况下

触发失效时机:笔记本显示以及显示器显示,两者的屏幕大小是不一样的

显示器正常显示 List 列表数据四条,当我将本地项目从显示器拖拽到笔记本显示后

变为了

其实数据在列表中,这时候是在缩放比为正常100%的情况下之下,当我缩小比例还是正常显示,但是按正常的交互来说这肯定是不对的。

因此代码修改只需替换 height:

复制代码
height='calc(100vh - 200px)'

当前的视口100vh减去内容 InfiniteScroll 除外的固定200px就能够实现滚动啦!

相关推荐
万粉变现经纪人12 小时前
如何解决 pip install shapely 报错 GEOS C 库未找到 问题
c语言·开发语言·python·pycharm·bug·pandas·pip
cyforkk13 小时前
前后端联调实战:解决业务异常被误判为成功的“幽灵 Bug”
bug·状态模式
li9056632801 天前
hanzi-writer-miniprogram Path2D问题以及Bug修复
微信小程序·bug
万粉变现经纪人1 天前
如何解决 pip install cx_Oracle 报错 未找到 Oracle Instant Client 问题
数据库·python·mysql·oracle·pycharm·bug·pip
ChoSeitaku3 天前
Git分支|创建分支|切换分支|合并分支|删除分支|合并冲突分支|分支策略|bug分支|强制删除分支
bug
Lxinccode3 天前
BUG(23) : node版claude code启动报错Failed to connect to api.anthropic.com: ETIMEDOUT
bug·claude·claude启动报错
buyulian4 天前
Bug防御体系:技术方案的优与劣
java·经验分享·bug·软件工程
川石课堂软件测试4 天前
接口测试需要注意的一些BUG
网络·数据库·python·单元测试·bug·压力测试·tornado
深念Y5 天前
记一个BUG:Trae里MongoDB和MySQL MCP不能共存
数据库·mysql·mongodb·ai·bug·agent·mcp
测试_AI_一辰5 天前
AI系统测试实践:Tool执行与状态管理(Agent系统最容易出Bug的地方)
人工智能·ai·自动化·bug·ai编程