我想将我的 React Final Form 的状态存储在某个地方。现在它在一个 React Hook 中。我目前正在使用useMethods
,类似于useState
。
我目前拥有的表单是多步骤过程的一部分,当我导航到表单不在的另一个页面时,它会被卸载(当然)。重新安装时,我想为表单提供初始值(可在此处获得)。
问题是,当我的状态改变时,表单会重新渲染,我总是陷入无限循环,因为:
FormSpy
商店形式的变化- 状态变了
- 表单被重新渲染
FormSpy
商店形式的变化- 等等...
我还有一个问题,当提供初始值时,字段状态未填充(脏、触摸等),因此重新安装时表单看起来很奇怪,因为某些标签与元字段相关联。似乎我们需要某种方式来存储所有表单状态,而不仅仅是包含Form
可以卸载和重新安装n次的组件的值。
我想要的是:
- 更改为立即存储在我的状态
- 重新渲染以某种方式记住(如果需要,我可以将其存储在我自己的状态中)触摸、脏等状态
我的出发点是查看带去抖动的自动保存(尽管我不需要去抖动,因为我将它存储在本地)。
处理这个问题的最佳方法是什么?