React+Hooks+Antd框架下ProFormSelect的重置

本文介绍了如何在React应用中使用ProFormSelect组件实现四级联查功能,遇到懒加载问题后,通过在onChange事件中添加hook并使用resetFields方法实现实时重置下级选项,以达到预期效果。
摘要由CSDN通过智能技术生成

问题:以下是一个四级联查

改变变电站选项,下面三级出现懒加载情况,默认显示上一步操作的内容。

希望出现的效果:改变变电站,以下三级(柜子、回路号、设备名称)重置;改变柜子,以下两级(回路号、设备名称)重置;改变回路号,设备名称重置。

解决方法:

给form增加钩子

//引入
import React, {useRef } from 'react';
//...
//钩子声明
  const formRef = useRef();
//...
//使用
<ModalForm 
  formRef={formRef} //增加钩子
  //...其他属性
>
    <ProFormSelect 
        label="变电站" 
        name="substationCode"
        //... 其他属性
        onChange={(value) => {
              //...   其他逻辑      
              setTimeout(() => {//在onChange事件中利用resetFields进行重置
                formRef?.current?.resetFields(["containerCode"]);                
                formRef?.current?.resetFields(["loopCode"]);
                formRef?.current?.resetFields(["equipName"]);
              }, 0);
              
            }}        
          />
    <ProFormSelect
          label="柜子"
          name="containerCode"
            //... 其他属性
          onChange={(value) => {
              //...   其他逻辑      
            setTimeout(() => {     
              formRef?.current?.resetFields(["loopCode"]);
              formRef?.current?.resetFields(["equipName"]);
            }, 0);
          }}
          
        /> 
    <ProFormSelect
          label="回路号"
          name="loopCode"
            //... 其他属性
          onChange={(value) => {
              //...   其他逻辑      
            setTimeout(() => {     
              formRef?.current?.resetFields(["loopCode"]);
              formRef?.current?.resetFields(["equipName"]);
            }, 0);
          }}
          
        />
    <ProFormSelect
          label="设备名称"
          name="equipName"
            //... 其他属性
          onChange={(value) => {
              //...   其他逻辑      
            setTimeout(() => {     
              formRef?.current?.resetFields(["loopCode"]);
              formRef?.current?.resetFields(["equipName"]);
            }, 0);
          }}
          
        />
          
          
        </ModalForm>

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值