使用React+ant Table 實現 表格無限循環滾動播放

數據大屏表格數據,當表格內容超出(出現滾動條)時,無限循環滾動播放,鼠標移入暫停滾動,鼠標移除繼續滾動;數據量小沒有超出時不需要滾動。
*使用時應注意,滾動區域高度=父元素高度 - 表頭高度
1、組件內容

import React, { useState, useEffect, useRef } from "react";
import { Table } from "antd";
import { ColumnsType, TableRef } from "antd/lib/table";
import styles from "./styles.less";
import Nodate from "../Other/nodata";interface InfiniteScrollTableProps<T> {/** 表格數據源 */dataSource: T[];/** 表格列定義 */columns: ColumnsType<T>;/*** 唯一字段*/rowKeyField: string;/*** 滾動速率。* @default 0.5* @description 建議在 0.5-3 之間調整* */speed?: number;
}/*** @description 無限循環滾動table*/
const InfiniteScrollTable = <T = any,>(props: InfiniteScrollTableProps<T>) => {const { dataSource, columns, speed = 0.5, rowKeyField = "key" } = props;const [doubleData, setDoubleData] = useState<any[]>([]);const tableRef = useRef<TableRef>(null);const animationRef = useRef<number | null>(null);const isHovered = useRef(false);// 滾動高度const scrollHeight = useRef(0);// 滾動動畫const startScrolling = (begin: boolean) => {if (isHovered.current || !tableRef.current || !tableHasScroll()) return;const table = tableRef.current.nativeElement;const wrapper = table.querySelector(".ant-table-body");if (!wrapper) {return;}// 重置滾動位置if (begin) {wrapper.scrollTop = 0;}const scroll = () => {if (isHovered.current) return;// 滾動到底部時重置位置if (wrapper.scrollTop >= wrapper.scrollHeight / 2) {wrapper.scrollTop = 0;} else {wrapper.scrollTop += speed;}animationRef.current = requestAnimationFrame(scroll);};animationRef.current = requestAnimationFrame(scroll);};// 表格內容是否出現滾動const tableHasScroll = () => {const table = tableRef.current?.nativeElement;const wrapper = table?.querySelector(".ant-table-body");if (!wrapper) {return false;}const hasScroll = wrapper.scrollHeight > wrapper.clientHeight;return hasScroll;};// 停止滾動const stopScrolling = () => {if (animationRef.current) {cancelAnimationFrame(animationRef.current);animationRef.current = null;}};// 處理鼠標事件const handleMouseEnter = () => {isHovered.current = true;stopScrolling();};const handleMouseLeave = () => {isHovered.current = false;startScrolling(false);};useEffect(() => {// 先設置為初始數據setDoubleData([...dataSource]);}, [dataSource]);// 開始滾動useEffect(() => {// 創建兩倍數據用于實現無縫滾動if (tableHasScroll() && doubleData.length === dataSource.length) {setDoubleData([...dataSource, ...dataSource]);}startScrolling(true);return () => stopScrolling();}, [tableRef.current, doubleData]);return (<divref={(el) => (scrollHeight.current = el?.clientHeight || 0)}className={styles["infinite-scroll-table"]}onMouseEnter={handleMouseEnter}onMouseLeave={handleMouseLeave}><Tableref={tableRef}columns={columns}dataSource={doubleData}pagination={false}scroll={{ y: scrollHeight.current - 57 }}rowClassName={(record, index) =>index % 2 === 0 ? styles["even-row"] : styles["odd-row"]}rowKey={(record: any, index) => (record?.[rowKeyField] ?? "") + index}/></div>);
};export default InfiniteScrollTable;

2、樣式

.infinite-scroll-table {position: relative;height: 100%;transition: all 0.3s ease;border: 1px solid rgba(187,187,187,1);.highlight {color: #40a9ff;font-weight: 600;}.even-row {background: rgba(255,255,255);height: 60px;}.odd-row {background: rgba(250,250,250);height: 60px;}:global {.ant-table-header{border-radius: 0;}.ant-table-thead > tr > th {background: rgba(242,242,242) !important;color: #333 !important;font-size: 14px;font-weight: 600;text-align: center;border-start-start-radius: 0 !important;border-start-end-radius: 0 !important;}.ant-table-body {scrollbar-width: none;-ms-overflow-style: none;}.ant-table-cell{font-weight: normal;font-size: 14px;}.ant-table-body::-webkit-scrollbar {display: none;}.ant-table-row:hover > td {background: rgba(64, 144, 255, 0.2) !important;}.ant-table-placeholder .ant-table-cell{border: none;}}}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/83872.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/83872.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/83872.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

機器人現可完全破解驗證碼:未來安全技術何去何從?

引言 隨著計算機視覺技術的飛速發展&#xff0c;機器學習模型現已能夠100%可靠地解決Google的視覺reCAPTCHAv2驗證碼。這標志著一個時代的結束——自2000年代初以來&#xff0c;CAPTCHA&#xff08;"全自動區分計算機與人類的圖靈測試"的縮寫&#xff09;一直是區分…

大模型安全測試報告:千問、GPT 全系列、豆包、Claude 表現優異,DeepSeek、Grok-3 與 Kimi 存在安全隱患

大模型安全測試報告&#xff1a;千問、GPT 全系列、豆包、Claude 表現優異&#xff0c;DeepSeek、Grok-3 與 Kimi 存在安全隱患 引言 隨著生成式人工智能技術的快速演進&#xff0c;大語言模型&#xff08;LLM&#xff09;正在廣泛應用于企業服務、政務系統、教育平臺、金融風…

docker 部署redis集群 配置

docker的網絡模式 網橋模式每次重啟容器都有可能導致容器ip地址變化&#xff0c;需要固定ip的自己自定義網絡&#xff0c;這里介紹的是默認網絡模式 docker創建容器 docker run --name redis6379 -p 6379:6379 -p 16379:16379 -v /etc/redis/redis6379:/etc/redis -d --r…

LabVIEW的AMC架構解析

此LabVIEW 程序基于消息隊列&#xff08;Message Queue&#xff09;機制構建 AMC 架構&#xff0c;核心包含消息生成&#xff08;MessageGenerator &#xff09;與消息處理&#xff08;Message Processor &#xff09;兩大循環&#xff0c;通過隊列傳遞事件與指令&#xff0c;實…

數據庫管理與高可用-MySQL主從復制與讀寫分離

目錄 #1.1MySQL主從復制原理 1.1.1MySQL支持的復制類型 1.1.2復制的工作過程 #2.1MySQL讀寫分離原理 2.1.1常見的MySQL讀寫分離為為兩種 #3.1主從復制讀寫分離的實驗案例 1.1MySQL主從復制的原理 MySQL 主從復制是一種常用的數據同步機制&#xff0c;用于將主數據庫&#xf…

Python60日基礎學習打卡Day45

之前的神經網絡訓練中&#xff0c;為了幫助理解借用了很多的組件&#xff0c;比如訓練進度條、可視化的loss下降曲線、權重分布圖&#xff0c;運行結束后還可以查看單張圖的推理效果。 如果現在有一個交互工具可以很簡單的通過按鈕完成這些輔助功能那就好了&#xff0c;他就是…

React項目的狀態管理:Redux Toolkit

目錄 1、搭建環境 2、Redux Toolkit 包含了什么 3、使用示例 &#xff08;1&#xff09;創建user切片 &#xff08;2&#xff09;合并切片得到store &#xff08;3&#xff09;配置store和使用store 使用js來編寫代碼&#xff0c;方便理解一些 1、搭建環境 首先&#xf…

父組件prop傳向子組件的值,被子組件直接v-model綁定 功能不生效

隱式修改組件屬性會導致功能異常 實際操作中發現&#xff0c;即便是父組件把簡單數據通過prop傳給了子組件&#xff0c;子組件再使用v-model綁定&#xff0c;也不行&#xff0c;響應式還是對異常 原vue2業務中存在組件定義某個類型為Object的屬性&#xff0c;然后將該屬性對象…

c#bitconverter操作,不同變量類型轉byte數組

緣起:串口數據傳輸的基礎是byte數組&#xff0c;write(buff,0,num)或者writeline(string)&#xff0c;如果是字符串傳輸就是string變量就可以了&#xff0c;但是在modbus這類hex傳遞時&#xff0c;就要遇到轉換了&#xff0c;拼湊byte數組時需要各種變量的值傳遞&#xff0c;解…

【Redis】set 類型

set 一. set 類型介紹二. set 命令sadd、smembers、sismemberscard、spop、srandmembersmove、srem集合間操作交集&#xff1a;sinter、sinterstore并集&#xff1a;sunion、sunionstore差集&#xff1a;sdiff、sdiffstore 三. set 命令小結四. set 內部編碼方式五. set 使用場…

02-Redis常見命令

02-Redis常見命令 Redis數據結構介紹 Redis是一個key-value的數據庫&#xff0c;key一般是String類型&#xff0c;不過value的類型多種多樣&#xff1a; 貼心小建議&#xff1a;命令不要死記&#xff0c;學會查詢就好啦 Redis為了方便學習&#xff0c;將操作不同數據類型的命…

Rk3568驅動開發_GPIO點亮LED_12

需求&#xff1a; 用配置寄存器方式控制點燈非常原始&#xff0c;現在采用更方便的Linux提供的pctrl和gpio子系統編寫字符驅動 1.設備樹配置&#xff1a; 現將開發板中呼吸燈關閉掉防止占用到我需要使用的引腳 /* Narnat 2025-5-29 RK3568 GPIO 無需設置pinctrl*/gpioled{co…

阿里云ACP云計算備考筆記 (3)——云存儲RDS

目錄 第一章 云存儲概覽 1、云存儲通用知識 ① 發展歷史 ② 云存儲的優勢 2、云存儲分類 3、文件存儲業務場景 第二章 塊存儲 1、塊存儲分類 2、云盤的優勢 3、創建云盤 4、管理數據盤 ① 格式化數據盤 ② 掛載數據盤 ③ 通過 API 掛載云盤 5、管理系統盤 ① 更…

亞矩陣云手機實測體驗:穩定流暢背后的技術邏輯?

最近在測試一款云手機服務時&#xff0c;發現亞矩陣的表現出乎意料地穩定。作為一個經常需要多設備協作的開發者&#xff0c;我對云手機的性能、延遲和穩定性要求比較高。經過一段時間的體驗&#xff0c;分享一下真實感受&#xff0c;避免大家踩坑。 ??1. 云手機能解決什么問…

STM32H562----------ADC外設詳解

1、ADC 簡介 STM32H5xx 系列有 2 個 ADC,都可以獨立工作,其中 ADC1 和 ADC2 還可以組成雙模式(提高采樣率)。每個 ADC 最多可以有 20 個復用通道。這些 ADC 外設與 AHB 總線相連。 STM32H5xx 的 ADC 模塊主要有如下幾個特性: 1、可配置 12 位、10 位、8 位、6 位分辨率,…

【Android】雙指旋轉手勢

一&#xff0c;概述 本文參考android.view.ScaleGestureDetector&#xff0c;對雙指旋轉手勢做了一層封裝&#xff0c;采用了向量計算法簡單實現&#xff0c;筆者在此分享下。 二&#xff0c;實例 如下&#xff0c;使用RotateGestureDetector即可委托&#xff0c;實現旋轉手…

B站的視頻怎么下載下來——Best Video下載器

B站&#xff08;嗶哩嗶哩&#xff09;作為國內最受歡迎的視頻平臺之一&#xff0c;聚集了無數優質內容&#xff1a;動漫番劇、游戲實況、學習課程、紀錄片、Vlog、鬼畜剪輯……總有那么些視頻讓人想反復觀看、離線觀看&#xff0c;甚至剪輯創作。 但你是否遇到過這樣的煩惱&am…

基于SFC的windows系統損壞修復程序

前言 在平時使用Windows操作系統時會遇到很多因為系統文件損壞而出現的錯誤 例如:系統應用無法打開 系統窗口(例如開始菜單)無法使用 電腦藍屏或者卡死 是如果想要修復很多人只能想到重裝系統。但其實Windows有一個內置的系統文件檢查器可以修復此類錯誤。 原理 SFC命令…

智紳科技 —— 智慧養老 + 數字健康,構筑銀發時代安全防護網

在老齡化率突破 21.3% 的當下&#xff0c;智紳科技以 "科技適老" 為核心理念&#xff0c;構建 "監測 - 預警 - 干預 - 照護" 的智慧養老閉環。 其自主研發的七彩喜智慧康養平臺&#xff0c;通過物聯網、AI 和邊緣計算技術&#xff0c;實現對老年人健康與安…

用函數實現模塊化程序設計(適合考研、專升本)

函數 定義&#xff1a;本質上是一段可以被連續調用、功能相對獨立的程序段 c語言是通過“函數”實現模塊化的。根據分類標準不同函數分為以下幾類。 用戶角度&#xff1a;庫函數、自定義函數 函數形式&#xff1a;有參函數、無參函數 作用域&#xff1a;外部函數、內部函數 …