【React】二次封装Antd的Table组件

2024-05-27 18:04

本文主要是介绍【React】二次封装Antd的Table组件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用Table并不难,但是每次使用都会伴随着很大一部分逻辑,如loding效果、表格分页筛选排序、调接口完毕后赋值等等,使用方法基本一致,所以可以将他们二次封装,从而减少代码量,提升代码可读性。

二次封装表格

import { Table, TableProps } from "antd"
import { useFetchTableData } from "./useFetchTableData"
import { useMemo } from "react"type Props = {dataKey?: string fetchMethod: (params: {}) => Promise<any>requestParam: { size: number; search: {}[] }onParamChange: (data: any) => void[key: string]: any 
}interface DataType {}const BasicTable = ({dataKey = "data_list", // 接口响应中list对应的keyfetchMethod,requestParam,onParamChange,...resetTableProps
}: Props) => {const memoParams = useMemo(() => {return { ...requestParam }}, [requestParam]) // 避免值类型一样的对象,触发两次请求// 请求表格数据const { loading, tableData } = useFetchTableData(fetchMethod, memoParams)const onTableChange: TableProps<DataType>["onChange"] = ({ current, pageSize }, // 分页filters, // 筛选_sorter, // 排序extra // 当前table数据 以及 当前行为) => {let paramsif (extra.action === "filter") {// 触发筛选,修改searchlet search = []for (let key in filters) {if (filters[key]) {search.push({ [key]: filters[key] })}}params = { ...requestParam, page: current, size: pageSize, search }} else {params = {...requestParam,page: current,size: pageSize,}}onParamChange(params)}return (<TableborderedonChange={onTableChange}loading={loading}dataSource={tableData[dataKey]}pagination={{total: tableData.total_count,showSizeChanger: false,current: tableData.page,pageSize: requestParam.size,showTotal: (t) => <span>{t}</span>,}}{...resetTableProps}/>)
}
export default BasicTable

请求相关

import { message } from "antd"
import { useEffect, useState } from "react"interface TableData {[key: string]: any // 允许任意字符串作为键,值的类型是 anydata_list: any[]total_count: numberpage: number
}
interface Response {code: numbermessage: stringdata: any
}export function useFetchTableData(fetchMethod: (params: {}) => Promise<any>,parameter: {}
) {const [loading, setLoading] = useState(false)const [tableData, setTableData] = useState<TableData>({data_list: [],total_count: 0,page: 1,})// 获取表格数据async function fetchTableData() {try {setLoading(true)const res: Response = await fetchMethod(parameter)if (res.code === 1) {setTableData(res.data)} else {message.warning(res.message)}} finally {setLoading(false)}}useEffect(() => {fetchTableData()}, [parameter])return { loading, tableData }
}

使用

interface DataType {...
}
const columns: ColumnsType<DataType> = [...]export default () => {const getList = async (params) => {// 发送请求并将响应res返回return res}const [requestParam, setParameter] = useState({page: 1,size: 10,search: [],start_time: "",end_time: "",})const memoParameter = useMemo(() => ({ ...requestParam }), [requestParam])return (<BasicTabledataKey="data" // 这里写data意味着dataSource使用调用接口返回的res.data.data,不写这行默认为res.data.data_list,可根据需求自行更改fetchMethod={getUserlist}requestParam={memoParameter}onParamChange={(data: any) => {setParameter({ ...requestParam, ...data })}}// 下面的都会被剩余参数接收columns={columns}rowKey="id"/>)
}

这篇关于【React】二次封装Antd的Table组件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1008203

相关文章

Python用Flask封装API及调用详解

《Python用Flask封装API及调用详解》本文介绍Flask的优势(轻量、灵活、易扩展),对比GET/POST表单/JSON请求方式,涵盖错误处理、开发建议及生产环境部署注意事项... 目录一、Flask的优势一、基础设置二、GET请求方式服务端代码客户端调用三、POST表单方式服务端代码客户端调用四

基于Python Playwright进行前端性能测试的脚本实现

《基于PythonPlaywright进行前端性能测试的脚本实现》在当今Web应用开发中,性能优化是提升用户体验的关键因素之一,本文将介绍如何使用Playwright构建一个自动化性能测试工具,希望... 目录引言工具概述整体架构核心实现解析1. 浏览器初始化2. 性能数据收集3. 资源分析4. 关键性能指

MySQL CTE (Common Table Expressions)示例全解析

《MySQLCTE(CommonTableExpressions)示例全解析》MySQL8.0引入CTE,支持递归查询,可创建临时命名结果集,提升复杂查询的可读性与维护性,适用于层次结构数据处... 目录基本语法CTE 主要特点非递归 CTE简单 CTE 示例多 CTE 示例递归 CTE基本递归 CTE 结

Olingo分析和实践之OData框架核心组件初始化(关键步骤)

《Olingo分析和实践之OData框架核心组件初始化(关键步骤)》ODataSpringBootService通过初始化OData实例和服务元数据,构建框架核心能力与数据模型结构,实现序列化、URI... 目录概述第一步:OData实例创建1.1 OData.newInstance() 详细分析1.1.1

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

MySQL 8 中的一个强大功能 JSON_TABLE示例详解

《MySQL8中的一个强大功能JSON_TABLE示例详解》JSON_TABLE是MySQL8中引入的一个强大功能,它允许用户将JSON数据转换为关系表格式,从而可以更方便地在SQL查询中处理J... 目录基本语法示例示例查询解释应用场景不适用场景1. ‌jsON 数据结构过于复杂或动态变化‌2. ‌性能要

解决1093 - You can‘t specify target table报错问题及原因分析

《解决1093-Youcan‘tspecifytargettable报错问题及原因分析》MySQL1093错误因UPDATE/DELETE语句的FROM子句直接引用目标表或嵌套子查询导致,... 目录报js错原因分析具体原因解决办法方法一:使用临时表方法二:使用JOIN方法三:使用EXISTS示例总结报错原

Golang如何对cron进行二次封装实现指定时间执行定时任务

《Golang如何对cron进行二次封装实现指定时间执行定时任务》:本文主要介绍Golang如何对cron进行二次封装实现指定时间执行定时任务问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录背景cron库下载代码示例【1】结构体定义【2】定时任务开启【3】使用示例【4】控制台输出总结背景

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

前端如何通过nginx访问本地端口

《前端如何通过nginx访问本地端口》:本文主要介绍前端如何通过nginx访问本地端口的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、nginx安装1、下载(1)下载地址(2)系统选择(3)版本选择2、安装部署(1)解压(2)配置文件修改(3)启动(4)