时间:2021-04-08 10:36:53 | 栏目:vue | 点击:次
悲伤
一开始一直以为initialValue是个好东西,这样我每次编辑的时候把数据传过来就行,后来发现不得行!给大家看看
就离谱,后面认真看了一下文档才知道这个玩意是默认值,第一次有了之后就一直是这个。
然后我在网上看用resetFields()这个方法,每次提交或者取消之后重置一下数据,然而我试了还是不得行,会变成每次点击显示的是上一次的数据,所以后面还是老老实实看了一下form的其他方法。
贴个图
解决
放弃initialValue
const [form] = useForm()
form.setFielsValue(currentItem)
用form带的设置数据方法。这样能够保证每次都是最新的。
随手一贴
也没啥上下文,就将就着看写法就行!!
const { visible, onEdit, onCancel, type, currentItem, ...modalProps } = props; const [form] = useForm() useEffect(() => { form.setFieldsValue({ ...currentItem }); }, [visible]) const onOk = () => { form.validateFields().then((values: any) => { onEdit(values) }) }
补充知识:antd Form表单initialValue设置无效的问题之一
在表格数据中,编辑数据时用到的表单需要使用initialValue 来设置初始值,
以下写法会导致initialValue设置无效。
当表单组件被<></> ,< div></ div> 等包裹时,initialValue设置无效
// initialValue 设置无效的写法 <Form.Item label="xxx"> {getFieldDecorator('xxx',{ initialValue:'default' })( <> <Input /> <span>....</span> </> ) } </Form.Item> // 正确的写法 <Form.Item label="xxx"> {getFieldDecorator('xxx',{ initialValue:'default' })( <Input /> ) } // <span></span> </Form.Item>