ant-design嵌套子表格实现每次只展开一个子表格(点击新的子表格收起原展开的子表格)
又遇到问题,记录一下吧,希望给同踩坑的小白一些帮助
首先功能需求:点击新的子表格收起原展开的子表格
解决问题的关键点:重新set expandedRowKeys的值
这个解决问题的点大家都能想到,主要是在什么时候去set这个值
下边是API里边的描述,我们使用这个参数就可以解决问题了
onExpandedRowsChange | 展开的行变化时触发 | function(expandedRows) |
expandedRowKeys | 展开的行,控制属性 | string[] |
首先初始设置一个expandedRowKeys的初始值,我这里用的hook
const [expandedRowKeys,setExpandedRowKeys] = useState(['']) // 这里注意一下expandedRowKeys需要的时string[],我这里是默认全部收起的
然后是table组件中
<Table
dataSource={{datasource}}
expandable={{
onExpand={{(expanded,record)=>onExpand(expanded,record)}} // 这个是用来请求子表格的后台数据方法,上一篇文章中有介绍到
onExpandedRowsChange:(expandedRows) => expandRows(expandedRows) // 展开的行变化时触发
expandedRowkeys: expandedRowKeys // 展开的行,控制属性
expandedRowRender: () => expandedRowRender() // 额外的展开行(就是我们的子表格)
}}
/>
剩下的就是各个属性对应的函数处理了
const onExpand = (expanded,record) => {
// 请求后台接口处理数据
}
const expandedRowRender = () => {
// 渲染我们的子表格
}
const expandRows = (rows) => {
// 这里可以打印一下rows看下是什么 --------点开是['',1] ['',2]的数组 ,最后一个是我们当前展开的行,我们最后set一个['',当前展开行的下标]到expandedRowKeys就可以实现 ‘点击新的子表格收起原展开的子表格’ 这个功能了
const arrTemp = ['']
setExpandedRowKeys(arrTemp.concat(row[row.length - 1]))
}
都是API里边的东西,平常多看一下大家应该都可以找到解决方法的~~
react小白上路,如果有哪里不对,希望各位大佬多多指出 (0_0)~~~~~~
ant-design嵌套子表格实现每次只展开一个子表格(点击新的子表格收起原展开的子表格)相关推荐
- 如何用 Blazor 实现 Ant Design 组件库?
本文主要分享我创建 Ant Design of Blazor 项目的心路历程,已经文末有一个 Blazor 线上分享预告. Blazor WebAssembly 来了! Blazor 这个新推出的前端 ...
- Ant Design Pro 项目图表组件点击事件
背景:使用框架配套图表组件charts 要求柱形图可实现点击事件 方法:onReady 官网:https://charts.ant.design/zh/docs/api/options/events ...
- Ant Design Vue子表格展开只展开一行,其他行折叠
背景 因为我的子列表数据都是用的一个变量,所以需要折叠其他的,要不然多个表格展开后,数据渲染都是一样的 下列列表是只可以展开一列的: 第一步: 直接抄我箭头指的那三行即可 :row-key=" ...
- Ant Design Vue 表格筛选时只进行前台的按页筛选修改为后台的全局筛选
原因分析 在我们使用 Ant Design Vue 表格筛选功能时会发现,如果只是按照例子来,只是前端的按页筛选,并不能都进行全局筛选,原因有两点: 1.我们筛选的时候,只是进行前端的数据过滤,并没有 ...
- Ant Design Pro使用之--EditableProTable 可编辑表格
前言--EditableProTable 与 ProTable的对比 首先:可编辑表格 EditableProTable 与 ProTable 的功能基本相同: 但是如果用ProTable的话,增和改 ...
- ant design表格添加loading效果
这里看一下ant design中表格添加loading效果. 在页面进来,获取数据时候 获取到数据的时候 实现方法: 这里只需要在要渲染的表格中添加,loading={XXXX} 即可.大括号里面的值 ...
- antd 表格树如何展开_React Ant Design树形表格的复杂增删改
React Ant Design树形表格的复杂增删改 最近由于业务接触了antd,使用antd完成一个复杂的树形表格的显示以及修改.在这其中碰见了很多坑,不少功能antd只写了初步的功能,更为细化 ...
- ant design vue table表格组件实现隔行变色
ant design vue table表格组件实现隔行变色 一.使用方法 html代码: <a-table:columns="patient":data-source=&q ...
- 使用 el-table 实现树形数据懒加载、点击行展开、每次只展示一条数据(大类)以及自定义表格合计值
1. 使用 el-table 实现树形数据懒加载 实现必需条件: lazy :load="loadNode" :tree-props="{ children: 'chil ...
最新文章
- TabLayout的指示器长度 的问题
- matlab字符衔接,matlab字符串连接(多个字符串)的经验,matlab字符串
- we-rich 小程序渲染富文本js库
- 防火墙技术指标---并发连接数/吞吐量
- c 子类对象 访问父类对象受保护成员_面向对象编程(OOP)
- oracle怎么查询和插入表,Oracle查询一个表的数据插入到另一个表
- 解决在iOS8环境下,当用户关闭定位服务总开关时,无法将APP定位子选项加入定位权限列表的问题...
- Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
- 调用webserver时出现:请求因 HTTP 状态 401 失败: Unauthorized。
- Bootstrap (remote)事件监听多次
- ac1900 linksys 恢复_linksys思科WRT1900ACS刷机变砖维修
- Bithumb Global AMA丨Cred加速实现开放金融-打造区块链上蚂蚁金服
- 利用Calendar类制作日历
- Vue中watch监听路由的使用场景
- 多行文本溢出隐藏省略号
- 897-了解微服务网关
- 卡牛科技软件测试实习面试题
- 小白重装系统教程_练习如何用u盘重装系统教程
- 在matlab神经网络中xite,神经网络的MATLAB实现苏析超
- Spring使用与两大核心(Bean,AOP)
热门文章
- 统计分析:偏度和峰度
- 估算项目的时间进度!
- 视频创作教程-蜜蜂剪辑软件
- Python实现读取当前粉丝数量及UP主信息(实时)源码分享
- dns怎么修改默认服务器,vps修改默认服务器dns
- oppor15计算机科学计算,解密OPPO R15的魅力所在,这组数字告诉你真相!
- html分级显示的下拉列表,在下拉列表中显示多级树形菜单
- 创新实训——飞讯(四)
- Python程序的错误:变量未定义(NameError: name ‘mesage’ is not defined.)
- 基于SSM的微信小程序在线视频学习平台