react实现table可拖拽表头(给react-jss样式传递参数、滚动条样式)
目录
- react实现table可拖拽表头
- 安装依赖
- resizableTitle / index.tsx
- drapTable.tsx
- 使用DragTable 组件
- 滚动条样式
- 效果
react实现table可拖拽表头
安装依赖
yarn add react-resizable
yarn add react-jss
resizableTitle / index.tsx
import { createUseStyles } from 'react-jss';
import { Resizable } from 'react-resizable';const useResizableTitleStyles = createUseStyles({resizableHandle : {position: 'absolute',right: '-5px',bottom: 0,zIndex: 1,width: '10px',height: '100%',cursor: 'col-resize'}
});
// 表头拖拽组件
export const ResizableTitle = ({ onResize, width, isNotResizable, ...restProps }) => {const classes = useResizableTitleStyles();// 新增处理函数,用于阻止事件冒泡const stopPropagation = (event) => event.stopPropagation();// isNotResizable 或者 没有宽度 不可拖拽console.log('isNotResizable',isNotResizable, width, 'restProps', restProps);if (!width || isNotResizable) { return (<th {...restProps} />) };return (<Resizablewidth={width}height={0}handle={<span className={classes.resizableHandle} onClick={stopPropagation} />}onResize={onResize}draggableOpts={{ enableUserSelectHack: false }}><th {...restProps} style={{ ...restProps?.style, userSelect: 'none' }} /></Resizable>);
};
drapTable.tsx
import type { TableProps } from 'antd';
import { Table } from 'antd';
import { useState, useMemo, useEffect, useCallback } from 'react';
import type { ColumnType } from 'antd/lib/table';
import { ResizableTitle } from './resizableTitle/index';
import { createUseStyles } from 'react-jss';interface TableStylesProps {paddingVertical?: number;paddingHorizontal?: number;
}
// 设置table的 cell里面的 padding
const useTableStyles = createUseStyles({base_table_com: {'& .ant-table-thead > tr > th, & .ant-table-tbody > tr > td, & .ant-table tfoot > tr > th, & .ant-table tfoot > tr > td':{padding: (cProps: TableStylesProps) =>`${cProps.paddingVertical ?? 10}px ${cProps.paddingHorizontal ?? 12}px`,},},
});export const DragTable = <RecordType extends Record<string, any> = any>(props: ICommonTableProps<RecordType>,
) => {const {showTotalNum = true,pagination,hidePagination,paddingVertical,paddingHorizontal,} = props;const [tablePagination, setTablePagination] = useState<any>(pagination);const classes = useTableStyles({ paddingVertical, paddingHorizontal });const { columns } = props;// 设置可拖拽的表头const [rescolumns, setResColumns] = useState<ColumnType<any>[]>(columns.filter((column) => !column.hide) || [],);// 拖拽后 重新设置列表宽度const handleResize = useCallback((index) => {return (txt: any, Resize: any) => {const temp = [...rescolumns];temp[index] = { ...temp[index], width: Resize.size.width };setResColumns(temp);};},[rescolumns],);// 把 columns 设置可拖拽的cellconst columnsMap: any[] = useMemo(() => {return (rescolumns?.map((column: any, index) => {return {...column,onHeaderCell: (col: any) => ({width: col.width,onResize: handleResize(index),isNotResizable: col.isNotResizable}),};}) || []);}, [rescolumns, handleResize]);useEffect(() => {const showTotal = {showTotal: (total: number, range: number[]) => {if (showTotalNum) {return `共{${props.pagination ? props.pagination?.total : 0}}条结果`;} else {return '';}},};if (!hidePagination) {setTablePagination(Object.assign({}, pagination ?? {}, showTotal));} else {setTablePagination(false);}}, [hidePagination, pagination, props.pagination, showTotalNum]);return (<Table{...props}columns={columnsMap}pagination={tablePagination}components={{ header: { cell: ResizableTitle } }}className={classes.base_table_com}/>);
};interface CommonColumn<T> extends ColumnType<T> {hide?: boolean;
}export interface ICommonTableProps<RecordType> extends TableProps<RecordType> {showTotalNum?: boolean;hidePagination?: boolean;columns: CommonColumn<RecordType>[]; // 重写 columns 类型paddingVertical?: number; // 上下paddingpaddingHorizontal?: number;// 左右padding
}
使用DragTable 组件
import { createUseStyles } from 'react-jss';
import { useEffect, useMemo, useState, useRef } from 'react';
import { DragTable } from './drapTable';
import { Space } from "antd"const TablePage = () => {const columns = [{title: '操作',width: 60,isNotResizable: true, // 设置操作栏固定不可拖拽render: (_, record) => (<Space size="middle"><a>删除</a></Space>),},{title: '编码',dataIndex: 'code',width: 100,},{title: '名称',width: 100,dataIndex: 'name',},{title: '测试',dataIndex: 'test',width: 400,},{title: '描述',dataIndex: 'des',width: 400,},];const dataSource = [{ id: 1, code: '001', name: '我是name1', test: '测试一下1', des: '描述一下' },{ id: 2, code: '002', name: '我是name2', test: '测试一下2', des: '描述一下2' },{ id: 3, code: '003', name: '我是name3', test: '测试一下3', des: '描述一下3' },{ id: 4, code: '004', name: '我是name4', test: '测试一下4', des: '描述一下4' },{ id: 5, code: '005', name: '我是name5', test: '测试一下5', des: '描述一下5' },{ id: 6, code: '006', name: '我是name6', test: '测试一下6', des: '描述一下6' },{ id: 7, code: '007', name: '我是name7', test: '测试一下7', des: '描述一下7' },{ id: 8, code: '008', name: '我是name8', test: '测试一下8', des: '描述一下8' },{ id: 9, code: '009', name: '我是name9', test: '测试一下9', des: '描述一下9' },];return (<><DragTablerowKey="id"paddingVertical={8}paddingHorizontal={10}columns={columns}dataSource={dataSource}scroll={{ x: 'max-content', y : 250 }}/></>);
};
export default TablePage;
滚动条样式
/* 设置滚动条的宽度和背景色 */
::-webkit-scrollbar {width: 6px; /* 垂直滚动条的宽度 */height: 6px; /* 水平滚动条的宽度 */background-color: #f5f5f5; /* 滚动条的背景色 */
}/* 设置滚动条的滑块 */
::-webkit-scrollbar-thumb {background-color: #999; /* 滑块的背景色 */border-radius: 4px; /* 滑块的圆角 */cursor: pointer;
}/* 设置滚动条的轨道 */
::-webkit-scrollbar-track {background-color: #f5f5f5; /* 轨道的背景色 */
}
效果

相关文章:
react实现table可拖拽表头(给react-jss样式传递参数、滚动条样式)
目录 react实现table可拖拽表头安装依赖resizableTitle / index.tsxdrapTable.tsx使用DragTable 组件滚动条样式效果 react实现table可拖拽表头 安装依赖 yarn add react-resizable yarn add react-jssresizableTitle / index.tsx import { createUseStyles } from react-js…...
如何跨过robots协议的限制爬取内容?
在讨论如何“跨过robots协议的限制爬取内容”之前,重要的是强调遵循网络礼仪和法律法规的必要性。robots协议(Robots Exclusion Standard)是网站所有者向网络爬虫(包括搜索引擎和其他自动化工具)传达其爬取意愿的一种方…...
Parasoft C++Test软件静态分析操作指南_编码规范/标准检查
系列文章目录 Parasoft CTest软件安装指南 Parasoft CTest软件静态分析操作指南_编码规范/标准检查 Parasoft CTest软件静态分析操作指南_软件质量度量 Parasoft CTest软件静态分析_自动提取静态分析数据生成文档 Parasoft CTest软件单元测试_操作指南 Parasoft CTest软件单元…...
[AIGC] CompletableFuture如何实现任务链式调用?
Java 中的 CompletableFuture 提供了多种方法来支持任务链式调用。这些方法允许你将一组操作链接在一起,形成一个任务链,每一个任务只有在上一个任务成功完成后才会被执行。现在,我们来看一下一些常用的链接任务的方法: thenAppl…...
神奇动物在哪里?斯洛文尼亚旅游之野生动物寻踪
不仅拥有优美动人的自然风光,斯洛文尼亚还以其丰富的生物多样性而闻名。得益于国家对大自然开展的保护工作,斯洛文尼亚超过三分之一的国土面积都被规划为保护区,拥有约1.5万种动物和6000种植物,其中不乏众多特有、稀有和濒危动植物…...
电商项目之有趣的支付签名算法
文章目录 1 问题背景2 思路3 代码实现 1 问题背景 在发起支付的时候,一般都需要对发送的请求参数进行加密或者签名,下文简称这个过程为“签名”。行业内比较普遍的签发算法有: (1)按支付渠道给定的字段排序进行拼接&am…...
Web开发核心
文章目录 1.http协议简介2.http协议特性3.http请求和响应协议4.最简单的Web程序5.基于flask搭建web⽹站6.浏览器开发者⼯具(重点) 1.http协议简介 HTTP协议是Hyper Text Transfer Protocol(超文本传输协议)的缩写,是用于 万维网(WWW:Norld W…...
【Python】【Scrapy 爬虫】理解HTML和XPath
为了从网页中抽取信息,必须对其结构有更多了解。我们快速浏览HTML、HTML的树状表示,以及在网页上选取信息的一种方式XPath。 HTML、DOM树表示以及XPath 互联网是如何工作的? 当两台电脑需要通信的时候,你必须要连接他们ÿ…...
【CTF Web】CTFShow web5 Writeup(SQL注入+PHP+位运算)
web5 1 阿呆被老板狂骂一通,决定改掉自己大意的毛病,痛下杀手,修补漏洞。 解法 注意到: <!-- flag in id 1000 -->拦截很多种字符,连 select 也不给用了。 if(preg_match("/\|\"|or|\||\-|\\\|\/|\…...
LeetCode 968.监控二叉树 (hard)
968.监控二叉树 力扣题目链接(opens new window) 给定一个二叉树,我们在树的节点上安装摄像头。 节点上的每个摄影头都可以监视其父对象、自身及其直接子对象。 计算监控树的所有节点所需的最小摄像头数量。 贪心思路: 从下往上看,局部最…...
数理逻辑:1、预备知识
17.1 命题和联结词 命题:可以判定真假的陈述句。(则悖论,祈使句,疑问句都不是命题) 原子命题:不能被分割为更小的命题的命题 例如: 2既是素数又是偶数 可以由$p: 2 是素数,…...
14-云原生监控体系-Redis_exporter 监控 MySQL[部署Dashborad告警规则实战]
文章目录 环境准备切片集群主从哨兵1. 部署1.1. 二进制方式1.1.1. 下载二进制包1.1.2. 部署1.2. docker-compose 容器方式1.3. 配置连接&认证参数1.3.1. 连接认证参数1.3.2. 配置服务控制 systemd2. 配置到 Prometheus3 Dashboard4. 告警规则...
DOS学习-目录与文件应用操作经典案例-xcopy
新书上架~👇全国包邮奥~ python实用小工具开发教程http://pythontoolsteach.com/3 欢迎关注我👆,收藏下次不迷路┗|`O′|┛ 嗷~~ 目录 一.前言 二.使用 三.案例 一.前言 xcopy命令是DOS系统中一个强大的文件和目录复制工具&…...
Midjourney是一个基于GPT-3.5系列接口开发的免费AI机器人
Midjourney是一个基于GPT-3.5系列接口开发的免费AI机器人,旨在提供多领域的智能对话服务。Midjourney在不同领域中有不同的定义和应用,以下是对其中两个主要领域的介绍: Midjourney官网:https://www.midjourney.com/ 一、AI绘画工…...
v-model详解
目录 原理 作用 表单类组件封装 编辑v-model简化代码 原理 v-model本质上是一个语法糖。例如应用在输入框上,就是value属性和input属性的合写。 作用 提供数据的双向绑定。 数据变,视图跟着变:value视图变,数据跟着变input 注意&…...
ArcGIS中分割与按属性分割的区别
1、分割ArcGIS批量导出各个市的县级行政边界 视频教学: ArcGIS批量导出各个市的县级行政边界002 2、ArcGIS批量导出全国各省的边界 视频教学: ArcGIS导出全国各省的边界003 推荐学习: ArcGIS全系列实战视频教程——9个单一课程组合系列直播回…...
就业班 第三阶段(ELK) 2401--5.20 day1 ELK 企业实战 ES+head+kibana+logstash部署(最大集群)
ELKkafkafilebeat企业内部日志分析系统 1、组件介绍 1、Elasticsearch: 是一个基于Lucene的搜索服务器。提供搜集、分析、存储数据三大功能。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java开发的ÿ…...
PCM和QAM
PCM(脉冲编码调制)和QAM(正交振幅调制)是两种不同的信号调制技术,它们在通信系统中有着不同的应用和特点。 PCM(脉冲编码调制) 概述 PCM是一种数字信号处理技术,用于将模拟信号转…...
Mongodb分布式id
1、分布式id使用场景 分布式ID是指在分布式系统中用于唯一标识每个元素的数字或字符串。在分布式系统中,各个节点或服务可能独立运行在不同的服务器、数据中心或地理位置,因此需要一种机制来确保每个生成的ID都是全局唯一的,以避免ID冲突。 …...
AI模型抉择:开源VS闭源,谁主沉浮?
AI模型抉择:开源VS闭源,谁主沉浮? 😄生命不息,写作不止 🔥 继续踏上学习之路,学之分享笔记 👊 总有一天我也能像各位大佬一样 🏆 博客首页 怒放吧德德 To记录领地 &am…...
RestClient
什么是RestClient RestClient 是 Elasticsearch 官方提供的 Java 低级 REST 客户端,它允许HTTP与Elasticsearch 集群通信,而无需处理 JSON 序列化/反序列化等底层细节。它是 Elasticsearch Java API 客户端的基础。 RestClient 主要特点 轻量级ÿ…...
idea大量爆红问题解决
问题描述 在学习和工作中,idea是程序员不可缺少的一个工具,但是突然在有些时候就会出现大量爆红的问题,发现无法跳转,无论是关机重启或者是替换root都无法解决 就是如上所展示的问题,但是程序依然可以启动。 问题解决…...
DeepSeek 赋能智慧能源:微电网优化调度的智能革新路径
目录 一、智慧能源微电网优化调度概述1.1 智慧能源微电网概念1.2 优化调度的重要性1.3 目前面临的挑战 二、DeepSeek 技术探秘2.1 DeepSeek 技术原理2.2 DeepSeek 独特优势2.3 DeepSeek 在 AI 领域地位 三、DeepSeek 在微电网优化调度中的应用剖析3.1 数据处理与分析3.2 预测与…...
React Native 开发环境搭建(全平台详解)
React Native 开发环境搭建(全平台详解) 在开始使用 React Native 开发移动应用之前,正确设置开发环境是至关重要的一步。本文将为你提供一份全面的指南,涵盖 macOS 和 Windows 平台的配置步骤,如何在 Android 和 iOS…...
在HarmonyOS ArkTS ArkUI-X 5.0及以上版本中,手势开发全攻略:
在 HarmonyOS 应用开发中,手势交互是连接用户与设备的核心纽带。ArkTS 框架提供了丰富的手势处理能力,既支持点击、长按、拖拽等基础单一手势的精细控制,也能通过多种绑定策略解决父子组件的手势竞争问题。本文将结合官方开发文档,…...
STM32标准库-DMA直接存储器存取
文章目录 一、DMA1.1简介1.2存储器映像1.3DMA框图1.4DMA基本结构1.5DMA请求1.6数据宽度与对齐1.7数据转运DMA1.8ADC扫描模式DMA 二、数据转运DMA2.1接线图2.2代码2.3相关API 一、DMA 1.1简介 DMA(Direct Memory Access)直接存储器存取 DMA可以提供外设…...
ESP32 I2S音频总线学习笔记(四): INMP441采集音频并实时播放
简介 前面两期文章我们介绍了I2S的读取和写入,一个是通过INMP441麦克风模块采集音频,一个是通过PCM5102A模块播放音频,那如果我们将两者结合起来,将麦克风采集到的音频通过PCM5102A播放,是不是就可以做一个扩音器了呢…...
Java 加密常用的各种算法及其选择
在数字化时代,数据安全至关重要,Java 作为广泛应用的编程语言,提供了丰富的加密算法来保障数据的保密性、完整性和真实性。了解这些常用加密算法及其适用场景,有助于开发者在不同的业务需求中做出正确的选择。 一、对称加密算法…...
NFT模式:数字资产确权与链游经济系统构建
NFT模式:数字资产确权与链游经济系统构建 ——从技术架构到可持续生态的范式革命 一、确权技术革新:构建可信数字资产基石 1. 区块链底层架构的进化 跨链互操作协议:基于LayerZero协议实现以太坊、Solana等公链资产互通,通过零知…...
SpringCloudGateway 自定义局部过滤器
场景: 将所有请求转化为同一路径请求(方便穿网配置)在请求头内标识原来路径,然后在将请求分发给不同服务 AllToOneGatewayFilterFactory import lombok.Getter; import lombok.Setter; import lombok.extern.slf4j.Slf4j; impor…...
