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)
        })
相关推荐
前端百草阁几秒前
Vue3 Diff 算法详解
前端·javascript·vue.js·算法·前端框架
im_AMBER1 分钟前
前后端对接: ESM配置与React Router
前端·javascript·学习·react.js·性能优化·前端框架·ecmascript
学且思3 分钟前
使用import.meta.url实现传递路径动态加载资源
前端·javascript·vue.js
problc5 分钟前
OpenClaw 的前端用的React还是Vue?
前端·vue.js·react.js
冰暮流星8 分钟前
javascript里面的return语句讲解
开发语言·前端·javascript
弓.长.9 分钟前
ReactNative for OpenHarmony项目鸿蒙化三方库:react-native-image-gallery — 图片画廊组件
react native·react.js·harmonyos
步步为营DotNet13 分钟前
使用.NET 11的Native AOT提升应用性能
java·前端·.net
Never_Satisfied13 分钟前
在JavaScript / HTML中,监听鼠标滚动事件
javascript·html·计算机外设
早點睡39015 分钟前
ReactNative项目OpenHarmony三方库集成实战:react-native-json-tree
react native·react.js·json
左耳咚15 分钟前
Claude Code 记忆系统与 CLAUDE.md
前端·人工智能·claude