Instance created by `useForm` is not connected to any Form element. Forget to pass `form` prop

最近在使用antd design pro中的proform,真的是踩坑太多了

昨天遇到的这个报错问题先记录一下

官方文档说:这是因为你在调用 form 方法时,Modal 还未初始化导致 form 没有关联任何 Form 组件。你可以通过给 Modal 设置 forceRender 将其预渲染。

但是我没有用Modal,直接使用的Proform,

但同理可得,报这个错的原因是因为表单没有初始化,Proform是对Form的进一步封装,所以同理

检查了代码发现我使用了isVisible去控制表单是否渲染,如上图,但是在isVisible=false的时候调用了表单刷新的方法(如下图),所以出现了上述问题

解决办法:在调用刷新表单方法的时候添加条件判断,是的一定是表单初始化后才调用上面的方法,如下图

没有直接使用isVisible来判断的原因是set更新是异步的,不能及时的拿到最新值

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值