ProTable/EditableProTable 无法用formRef.current.setFieldsValue修改table某一行的值

1.背景

ProTable的编辑表格(开启editable),无法用formRef.current.setFieldsValue修改某一行的值,坑又来了…

2.解决

需要做个包装,Table外层增加ProForm和ProFormItem,ProTable增加属性name="xx"即可解决

<ProForm formRef={formRef} submitter={false}>
  <ProFormItem>
    <ProTable
      name="table"//属性名自己定义
      columns={columns}
      rowKey="id"
      editable={{
        form: form,
        type: 'multiple',
        ...
  }}
    />
  </ProFormItem>
</ProForm>
// 这是某一行的保存按钮
<Button
onClick={() => {
console.log('表格数据',form.current?.getFieldsValue().table;);
}}
>保存</Button>

在这里插入图片描述
上图可以看到打印出来的key是下标,值为每一行的表格数据,所以可以通过下标(index)或者rowKey也就是绑定的id拿到每一条数据,然后在赋值整个table即可。

<Button
onClick={({index}) => {
let tableData = form.current?.getFieldsValue().table;
// 通过下标 如果按钮实在columns中定义,里面就能拿到index, 反正在哪基本都能获取下标
  let row = tableData[index];//当前行
  row.name='沐歌'//修改值
  tableData[index] = row//重新赋值
  formRef.current.setFieldsValue({//表格重新赋值
    table: Object.values(tableData),
  });
}}
>保存</Button>

3.参考

点我打开地址

summary={ () => ( <> <ProTable.Summary.Row className='total' style={{textAlign: 'center'}}> {/* 合计行内容 */} <ProTable.Summary.Cell colSpan={2} index={0} >总计</ProTable.Summary.Cell> <ProTable.Summary.Cell index={2}>{summaryData && summaryData.batteryOperationCabinetTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={3}>{summaryData && summaryData.batteryOperationUserBindingTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={4}>{summaryData && summaryData.batteryOperationBLeasingTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={5}>{summaryData && summaryData.batteryOperationChannelTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={6}>{summaryData && summaryData.batteryOperationSumTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={7}>{summaryData && summaryData.batteryMaintainWarehouseTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={8}>{summaryData && summaryData.batteryMaintainFactoryTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={9}>{summaryData && summaryData.batteryMaintainSumTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={10}>{summaryData && summaryData.batteryRetireScrapTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={11}>{summaryData && summaryData.batteryRetireBuyBackTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={12}>{summaryData && summaryData.batteryRetireSumTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={13}>{summaryData && summaryData.batteryLibrarySumTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={14}>{summaryData && summaryData.batteryCountedSumTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={15}>{summaryData && summaryData.batteryStatusSumTotal}</ProTable.Summary.Cell> <ProTable.Summary.Cell index={16}>{summaryData && summaryData.batteryAvailability}</ProTable.Summary.Cell> </ProTable.Summary.Row> </> )} 这段代码怎么通过遍历对象转成可读性更高的代码
07-16
<div> <Space direction="vertical" size="large" style={{display: 'flex', marginTop: '1%'}}> <DatePicker onChange={onChange} disabledDate={disabledDate} defaultValue={dayjs()} /> <ProTable<API.EleYj, API.getEleYjByConditionParams & API.PageParams> headerTitle={'深圳市能源换电业务电池总体情况'} rowKey="" bordered search={false} // scroll={{x:true}} scroll={{x: 'max-content', y: 700}} request={async (params) => { console.log(params); return await getEleYjByCondition(params); }} options={{ // show: true, density: true, fullScreen: true, setting: true, } } columns={columns} summary={ () => ( <> <ProTable.Summary.Row className='total' style={{textAlign: 'center'}}> {/* 合计行内容 */} <ProTable.Summary.Cell colSpan={2} index={0} >合计</ProTable.Summary.Cell> <ProTable.Summary.Cell index={2}>3232</ProTable.Summary.Cell> <ProTable.Summary.Cell index={3}>43</ProTable.Summary.Cell> <ProTable.Summary.Cell index={4}>345</ProTable.Summary.Cell> <ProTable.Summary.Cell index={5}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={6}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={7}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={8}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={9}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={10}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={11}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={12}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={13}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={14}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={15}>534</ProTable.Summary.Cell> <ProTable.Summary.Cell index={16}>3232</ProTable.Summary.Cell> </ProTable.Summary.Row> </> )} /> </Space> </div>怎么把datepicker放在protable
07-14
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值