为什么在文件上传表单上的formik的values对象中文件对象为空?

问题描述

我正在尝试使用formik上传文件,但是文件对象始终为空,我无法完全弄清楚。这是codesandBox链接-https://codesandbox.io/s/formik-file-input-with-validation-forked-r5jqg?file=/src/App.js

我从github-https://github.com/formium/formik/issues/926上的此问题中获得了此实现。

非常感谢您的帮助。

解决方法

您正在将object的{​​{1}}设置为最初为e.target.files[0]的{​​{1}}。您需要将file设置为undefined。也不要针对您的状态对象e.taregt.files[0]。您需要设置名称和大小,因为这是验证架构和显示所需要的。我已经评论了验证模式支持的格式,因为reader.readAsDataURL(file)可以通过file键直接提及接受的格式。

这是我工作的修改版sandbox