方法一:使用 setFieldsValue()
方法(推荐
)
首先,解构出form实例
const [form] = Form.useForm()
然后,将该实例与Form绑定
<Form form={form} ...>...</Form>
恰当时机,调用setFieldsValue()方法赋值
form.setFieldsValue(Object)
// 常见场景如页面表单回显
useEffect(() => {
// 假设 asyncData 是异步获取的数据
// 在数据获取后,设置表单的初始值
if (asyncData) {
form.setFieldsValue({
fieldName: asyncData.value,
// 其他字段的初始值
// field2: asyncData.someOtherValue,
})
}
}, [asyncData, form])
方法二:使用 Form 表单的 initialValues
属性
<Form initialValues={Object} ...>...</Form>
这种方法只能在初始的时候生效,适用于表单项初始值为「写死」的场景。
如果这个值是state,是无法导致Form中的数据发生变化的。如果需要二次修改,请使用方法一:setFieldsValue()方法。
官网说明如下