在antd4.0中Form使用initialValue操作
悲伤
【在antd4.0中Form使用initialValue操作】一开始一直以为initialValue是个好东西,这样我每次编辑的时候把数据传过来就行,后来发现不得行!给大家看看
就离谱,后面认真看了一下文档才知道这个玩意是默认值,第一次有了之后就一直是这个。
然后我在网上看用resetFields()这个方法,每次提交或者取消之后重置一下数据,然而我试了还是不得行,会变成每次点击显示的是上一次的数据,所以后面还是老老实实看了一下form的其他方法。
贴个图
文章图片
解决
放弃initialValue
const [form] = useForm()用form带的设置数据方法。这样能够保证每次都是最新的。
form.setFielsValue(currentItem)
随手一贴
也没啥上下文,就将就着看写法就行!!
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 设置无效的写法{getFieldDecorator('xxx',{ initialValue:'default'})( <> .... >) } // 正确的写法{getFieldDecorator('xxx',{ initialValue:'default'})( ) } //
以上这篇在antd4.0中Form使用initialValue操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
推荐阅读
- Vue2中无法检测到数组变动的原因及解决
- 向量处理器中的向量指令格式
- 操作系统中的非连续分配详细指南
- 华为录音机文件在哪个文件夹
- Win8浏览照片应用中的图片提示没有文件怎样办?
- Win8.1升级Win10卡在99%出错80240031的处理办法
- Win8程序属性菜单中没有兼容性选项怎样处理?
- 如何恢复Win8系统回收站中被清空的文件?
- android中的文件操作详解以及内部存储和外部存储(转载)
- 在 Android 上配置 GNU/Linux Chroot 环境