【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;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/573197.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Python之PCV库安装教程以及解说

PCV库是一个比较古老的python库 在网上参考了很多教程 于是现在想要总结一下,并且分享整理了一下资源 很多人是通过pycharm内部直接下载PCV 但是导入时还要报错 因为PCV版本不对 pycharm自动下载的版本过于旧 是0.0.2 而我们需要的是1.0.0版本 否则下面PCV部分会报错无法导入…

Android—统一依赖版本管理

依赖版本管理有多种方式 config.gradle 用于Groovy DSL&#xff0c;新建一个 config.gradle 文件&#xff0c;然后将项目中所有依赖写在里面&#xff0c;更新只需修改 config.gradle文件内容&#xff0c;作用于所有module buildSrc 可用于Kotlin DSL或Groovy DSL&#xff0c;…

阿里服务器centos7宝塔部署docker-compose项目

这里写目录标题 整体项目所使用的服务如下阿里云服务器操作安装宝塔面板小程序docker部署如果报错容器数量显示0 最近搞了个AI角色游戏的小程序&#xff0c;玩一玩练练手&#xff0c;因为项目需要复制部署&#xff0c;就研究下了docker&#xff0c;然后客户很多都是宝塔&#x…

【CMU15-445 Part-19】Multi-Version Concurrency Control

Part19-Multi-Version Concurrency Control 其实说到底 MVCC不仅是一种并发控制协议&#xff0c;更是一个系统构建&#xff08;数据组织的方法&#xff09;。 简介 writer 不会 block readers&#xff0c;reader 也不会 block writers。只读事务可以读到一个consistent的sna…

Clion连接MySQL数据库:实现C/C++语言与MySQL交互

确保你的电脑里已经有了MySQL。 1、找到MySQL的目录 2、进入lib目录 3、复制libmysql.dll和libmysql.lib文件 4、将这俩文件粘贴到你的clion项目的cmake-build-debug目录下 如果不是在这个目录下&#xff0c;运行时会出以下错误报错&#xff1a; 进程已结束&#xff0c;退…

【go零基础】go-zero从零基础学习到实战教程 - 2项目初始化

到项目初始化过程了&#xff0c;这边的项目设计完全按照作者自己的喜好来进行定义和设置的&#xff0c;所以各位完全可以按照自己的偏好自喜设置哈。 首先是创建一个工作文件夹哈。 别问为啥不直接quickstart&#xff0c;因为quickstart生成的api名字是greet&#xff0c;改起来…

抗D盾是什么,为什么游戏被攻击了需要抗D盾

游戏行业DDoS攻击的主要原因是因为游戏产品生命周期偏短&#xff0c;而DDoS供给成本又不高&#xff0c;只要发起攻击&#xff0c;企业为确保游戏稳定运营而不得不快速做出让步&#xff0c;致使敲诈勒索的成功率相对更高。在遭受DDoS攻击后&#xff0c;游戏公司的日损失甚至多达…

c4d渲染动画可以暂停吗?c4d云渲染动画怎么暂停

C4D是一款广泛应用于3D建模和动画制作的软件。在进行动画渲染时&#xff0c;用户有时会希望能够暂停渲染过程&#xff0c;以便进行其他操作或调整渲染设置。根据搜索结果&#xff0c;C4D在渲染动画时确实支持暂停功能。 一、c4d渲染动画怎么暂停 1、暂停渲染 C4D允许用户在渲…

druid数据库连接池配置项说明

目录 一、druid简介 二、引入druid数据库连接池 三、druid数据库连接池配置项说明 1. initialSize 2.maxWait 3.validationQuery 4.testWhileIdle&#xff0c;testOnBorrow&#xff0c;testOnReturn 5.timeBetweenEvictionRunsMillis 6.minEvictableIdleTimeMillis 7…

linux 驱动-匹配2 (amba_bustype)

目录 1.实例分析 a. 设备树实例 b. 驱动实例 2. amba匹配流程 a. 创建amba_device b. 确定总线以及总线的匹配函数 c. 分析总线的匹配函数 1.实例分析 a. 设备树实例 serial7e201000 { compatible "brcm,bcm2835-pl011\0arm,pl011\0arm,primecell"; //创建am…

Nginx 四层和七层代理区别、配置

四层&#xff1a;通过报文中的目标地址和端口&#xff0c;加上负载均衡设备设置的服务器选择方式&#xff0c;决定最终选择的内部服务器&#xff0c;使用tcp、udp协议。 七层&#xff1a;"内容交换"&#xff0c;通过报文中真正有意义的应用层内容&#xff0c;加上负…

【vue,unapi】UniApp引入全局js实现全局方法,全局变量

创建一个全局文件utils.js export const baseUrl "https://www.baidu.com/"export const fn () > {console.log("demo"); } export const obj {baseUrl : "https://www.baidu.com/",demo(){console.log("demo2");} }第一种&#…

基于opencv的单目相机标定

openCv版本&#xff1a;4.4.0 从源码处拷贝标定代码出来使用&#xff0c;需要拷贝samples/cpp/tutorial_code/calib3d/camera_calibration 需要的文件如下&#xff1a; -rw-rw-r-- 1 rog rog 28490 Jul 18 2020 camera_calibration.cpp -rw-rw-r-- 1 rog rog 3152 Jul 18 …

LearnOpenGL(五)之变换

一、缩放&#xff08;Scaling&#xff09; 把缩放变量表示为 (S1,S2,S3)&#xff0c; 将任意向量 (x,y,z) 定义一个缩放矩阵&#xff0c;缩放公式&#xff1a; 二、位移 和缩放矩阵一样&#xff0c;在44矩阵上有几个特别的位置用来执行特定的操作&#xff0c;对于位移来说它们…

通过matlab对比遗传算法优化前后染色体的变化情况

目录 1.程序功能描述 2.测试软件版本以及运行结果展示 3.核心程序 4.本算法原理 5.完整程序 1.程序功能描述 通过matlab对比遗传算法优化前后染色体的变化情况. 2.测试软件版本以及运行结果展示 MATLAB2022A版本运行 3.核心程序 ....................................…

JVM(Java虚拟机)练习题目大全

1、什么是Java虚拟机&#xff08;JVM&#xff09;&#xff1f;它的作用是什么&#xff1f; Java虚拟机是Java平台的关键组件之一&#xff0c;它是一个能够执行Java字节码的虚拟计算机。其作用是提供一个跨平台的运行环境&#xff0c;使得Java程序可以在不同的操作系统上运行&a…

javaEE初阶——多线程(九)——JUC常见的类以及线程安全的集合类

T04BF &#x1f44b;专栏: 算法|JAVA|MySQL|C语言 &#x1faf5; 小比特 大梦想 此篇文章与大家分享多线程专题的最后一篇文章:关于JUC常见的类以及线程安全的集合类 如果有不足的或者错误的请您指出! 目录 3.JUC(java.util.concurrent)常见的类3.1Callable接口3.2 RentrantLoc…

5月计算机各省报名时间汇总报名流程

&#x1f4e3;5月有5省可进行计算机报名 天津&#xff1a;5月6日-5月10日 福建&#xff1a;5月6日9:00-5月12日17:00 广西&#xff1a;5月6日9:00-5月12日23:55 重庆&#xff1a;5月6日9:00-5月12日24:00 西藏&#xff1a;预计5月6日-12日 &#x1f50d;计算机等级考试报…

【智能算法应用】灰狼算法(GWO)在低照度图像增强中的应用

目录 1.算法原理2.数学模型3.结果展示4.参考文献 1.算法原理 【智能算法】灰狼算法&#xff08;GWO&#xff09;原理及实现 2.数学模型 对于低照度图像的增强方式可以采用非线性变换函数来对图像的灰度值进行变化&#xff0c;对于不同环境下质量不同的图像&#xff0c;可以将…

Flink 实时数仓(一)【实时数仓离线数仓对比】

前言 昨天技术面的时候&#xff0c;面试官说人家公司现在用的都是最新的技术&#xff0c;比如 Doris 等一些最新的工具&#xff0c;确实这些课是学校永远不会开设的&#xff0c;好在他说去了会带着我做一做。可是 ...... 学院舍不得让走啊 ...... 没办法&#xff0c;情况就是这…