【JS】react antd 项目如何让Table组件表格滚动播放

实现原理

某个函数实现向下滚动1个像素效果,使用setInterval每隔1秒都调用这个函数,就实现了滚动的效果。

init = () => {
	const that = this;
	this.timeInterval = setInterval(() => {
		const dom = that.divRef.current.getElementsByClassName("ant-table-body')[0]
		const { crowedScrollTop} = that.state
		that.setstate({
			crowedScrollTop: crowedScrollTop+ 1}, () => {
			const {crowedScrollTop: newTop } = that.state;
			dom.scrollTop = newTop;
		});
		if (Math.ceil(dom.scrollTop) >= dom.scrollHeight - dom.clientHeight {
			dom.scrollTop = 0;
			if(dom.scrollHeight > dom.clientHeight {
				// 刷新表格
			}
			that.setstate({ crowedScrollTop:0 })
		}
	}, 100)
}

渲染逻辑

this.divRef = React.createRef();
<div ref={this.divRef}>
	<Table />
</div>

如何判断是否滚到到底部?

if (Math.ceil(dom.scrollTop) >= dom.scrollHeight - dom.clientHeight)

dom.scrollTop: 当前滚动元素的顶部已经滚动过去的像素值。如果这个值为0,说明元素还没有滚动;如果这个值等于或接近dom.scrollHeight - dom.clientHeight,说明元素已经滚动到底部。

dom.scrollHeight: 滚动元素的总高度,包括因溢出而不可见的内容。

dom.clientHeight: 滚动元素的可视区域的高度。

停止和开始滚动的控制

提供一种机制(如按钮或鼠标悬停事件)来控制滚动的开始和停止。
当用户与表格交互(例如点击或滚动)时,可能需要暂停自动滚动。

addScrollEvent = () => {
	const that = this;
	const dom = that.divRef.current.getElementsByClassName("ant-table-body')[0]
	dom.onmouseover = () => {
		that.clear();
	}
	dom.onmouseout = () => {
		that.init();
	}
	dom.onscroll = () => {
		if(dom) {
			that.setState({
				// 保存自行滚动的高度
				crowedScrollTop: dom.scrollTop
			})
		}
	}
}

clear = () => {
	this.timeInTERVAL && clearInterval(this.timeInterval)
}

优化滚动体验

考虑使用requestAnimationFrame来替代setInterval,以实现更平滑的滚动效果。
避免在滚动过程中进行大量计算或DOM操作,以免影响性能。

import React, { useRef, useEffect, useState } from 'react';  
  
const MyComponent = () => {  
  const divRef = useRef(null);  
  const [crowedScrollTop, setCrowedScrollTop] = useState(0);  
  
  useEffect(() => {  
    const dom = divRef.current.getElementsByClassName('ant-table-body')[0];  
  
    if (dom) {  
      let frameId; // 将 frameId 声明在 useEffect 的作用域内  
  
      function autoScroll() {  
        if (crowedScrollTop < dom.scrollHeight) {  
          setCrowedScrollTop(crowedScrollTop => crowedScrollTop + 1);  
          dom.scrollTop = crowedScrollTop;  
          frameId = requestAnimationFrame(autoScroll); // 更新 frameId  
        } else {  
          dom.scrollTop = 0;  
          setCrowedScrollTop(0);  
          // 刷新表格  
        }  
      }  
  
      frameId = requestAnimationFrame(autoScroll); // 初始化 frameId  
  
      // 清理函数  
      return () => {  
        cancelAnimationFrame(frameId); // 使用在 useEffect 作用域内声明的 frameId  
      };  
    }  
  }, []); // 注意,这个effect只在组件挂载时运行一次  
  
  // 渲染逻辑  
  return (  
    <div ref={divRef}>  
      {/* ...表格内容... */}  
    </div>  
  );  
};  
  
export default MyComponent;
  • 7
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值