react 分步表单中使用useEffect来更新表单值的问题

问题背景:我在完成一个分步表单的功能的时候,在进行点击下一步的时候,会通过useEffect 来监听下一步或者上一步的动作,进行表单赋值,我使用

复制代码
    useEffect(() => {
        setFieldsValue(formValues);
    }, [stepNum])

直接赋值的时候就会提示

Warning: You cannot set a form field before rendering a field associated with the value.

原因是因为使用 getFieldDecorator 注册的值,在这个时候表单设置值的时候没有这些字段,导致的异常提示。

解决方案:

使用 form.getFieldsValue 来获取当前项,然后对比赋值,最终在调用 setFieldsValue(obj)即可。这个时候obj就不包含其他未注册的值了

formValues 是收集到的每项表单的值。

复制代码
 Object.keys(form.getFieldsValue()).forEach(key => {
            const obj = {};
            obj[key] = formValues[key] || null;
             setFieldsValue(obj)
        })
相关推荐
IT_陈寒12 分钟前
Python高手都在用的5个隐藏技巧,让你的代码效率提升50%
前端·人工智能·后端
lcc18726 分钟前
Vue3 ref函数和reactive函数
前端·vue.js
艾小码28 分钟前
还在为组件通信头疼?defineExpose让你彻底告别传值烦恼
前端·javascript·vue.js
gnip29 分钟前
docker总结
前端
槁***耿29 分钟前
TypeScript类型推断
前端·javascript·typescript
带只拖鞋去流浪31 分钟前
迎接2026,重新认识Vue CLI (v5.x)
前端·vue.js·webpack
y***548837 分钟前
TypeScript在React项目中的状态管理
javascript·react.js·typescript
全马必破三3 小时前
CSS 和 JS 如何阻塞浏览器渲染 DOM
javascript
c***V3234 小时前
Vue优化
前端·javascript·vue.js
努力往上爬de蜗牛5 小时前
react native真机调试
javascript·react native·react.js