又遇到问题,记录一下吧,希望给同踩坑的小白一些帮助

首先功能需求:点击新的子表格收起原展开的子表格

解决问题的关键点:重新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嵌套子表格实现每次只展开一个子表格(点击新的子表格收起原展开的子表格)相关推荐

  1. 如何用 Blazor 实现 Ant Design 组件库?

    本文主要分享我创建 Ant Design of Blazor 项目的心路历程,已经文末有一个 Blazor 线上分享预告. Blazor WebAssembly 来了! Blazor 这个新推出的前端 ...

  2. Ant Design Pro 项目图表组件点击事件

    背景:使用框架配套图表组件charts 要求柱形图可实现点击事件 方法:onReady 官网:https://charts.ant.design/zh/docs/api/options/events ...

  3. Ant Design Vue子表格展开只展开一行,其他行折叠

    背景 因为我的子列表数据都是用的一个变量,所以需要折叠其他的,要不然多个表格展开后,数据渲染都是一样的 下列列表是只可以展开一列的: 第一步: 直接抄我箭头指的那三行即可 :row-key=" ...

  4. Ant Design Vue 表格筛选时只进行前台的按页筛选修改为后台的全局筛选

    原因分析 在我们使用 Ant Design Vue 表格筛选功能时会发现,如果只是按照例子来,只是前端的按页筛选,并不能都进行全局筛选,原因有两点: 1.我们筛选的时候,只是进行前端的数据过滤,并没有 ...

  5. Ant Design Pro使用之--EditableProTable 可编辑表格

    前言--EditableProTable 与 ProTable的对比 首先:可编辑表格 EditableProTable 与 ProTable 的功能基本相同: 但是如果用ProTable的话,增和改 ...

  6. ant design表格添加loading效果

    这里看一下ant design中表格添加loading效果. 在页面进来,获取数据时候 获取到数据的时候 实现方法: 这里只需要在要渲染的表格中添加,loading={XXXX} 即可.大括号里面的值 ...

  7. antd 表格树如何展开_React Ant Design树形表格的复杂增删改

    React Ant Design树形表格的复杂增删改 ​ 最近由于业务接触了antd,使用antd完成一个复杂的树形表格的显示以及修改.在这其中碰见了很多坑,不少功能antd只写了初步的功能,更为细化 ...

  8. ant design vue table表格组件实现隔行变色

    ant design vue table表格组件实现隔行变色 一.使用方法 html代码: <a-table:columns="patient":data-source=&q ...

  9. 使用 el-table 实现树形数据懒加载、点击行展开、每次只展示一条数据(大类)以及自定义表格合计值

    1. 使用 el-table 实现树形数据懒加载 实现必需条件: lazy :load="loadNode" :tree-props="{ children: 'chil ...

最新文章

  1. TabLayout的指示器长度 的问题
  2. matlab字符衔接,matlab字符串连接(多个字符串)的经验,matlab字符串
  3. we-rich 小程序渲染富文本js库
  4. 防火墙技术指标---并发连接数/吞吐量
  5. c 子类对象 访问父类对象受保护成员_面向对象编程(OOP)
  6. oracle怎么查询和插入表,Oracle查询一个表的数据插入到另一个表
  7. 解决在iOS8环境下,当用户关闭定位服务总开关时,无法将APP定位子选项加入定位权限列表的问题...
  8. Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
  9. 调用webserver时出现:请求因 HTTP 状态 401 失败: Unauthorized。
  10. Bootstrap (remote)事件监听多次
  11. ac1900 linksys 恢复_linksys思科WRT1900ACS刷机变砖维修
  12. Bithumb Global AMA丨Cred加速实现开放金融-打造区块链上蚂蚁金服
  13. 利用Calendar类制作日历
  14. Vue中watch监听路由的使用场景
  15. 多行文本溢出隐藏省略号
  16. 897-了解微服务网关
  17. 卡牛科技软件测试实习面试题
  18. 小白重装系统教程_练习如何用u盘重装系统教程
  19. 在matlab神经网络中xite,神经网络的MATLAB实现苏析超
  20. Spring使用与两大核心(Bean,AOP)

热门文章

  1. 统计分析:偏度和峰度
  2. 估算项目的时间进度!
  3. 视频创作教程-蜜蜂剪辑软件
  4. Python实现读取当前粉丝数量及UP主信息(实时)源码分享
  5. dns怎么修改默认服务器,vps修改默认服务器dns
  6. oppor15计算机科学计算,解密OPPO R15的魅力所在,这组数字告诉你真相!
  7. html分级显示的下拉列表,在下拉列表中显示多级树形菜单
  8. 创新实训——飞讯(四)
  9. Python程序的错误:变量未定义(NameError: name ‘mesage’ is not defined.)
  10. 基于SSM的微信小程序在线视频学习平台