我的问题......我如何使用 FilePond 但 onclick 上传文件,而不是像开箱即用那样自动上传文件?此外,由于我需要对这些图像采取一些其他操作(例如在上传之前显示它们以供查看),并且因为我需要将其他数据添加到要发送的 FormData 中(以及向 Redux 发送操作)。
通常我会创建一个 FormObject 将文件和其他值附加到它,然后再将其发布到某个端点(需要任何自定义标头)。但是,当我检查 FilePond 实例时,似乎我唯一可以访问的是 blob ......而不是实际文件。这是准确的吗?我是否需要遵循一些特殊的 FilePond 特定技术才能使文件上传正常工作?
FilePond 的文档有一个名为“server”的自定义配置值,它似乎可以访问更高级示例中的实际文件,所以这是必须完成的方式吗?我不能只抓取文件(从我目前在 FilePond 实例上看不到的某个地方)并将它们附加到一个对象以在我的正常“服务”中使用吗?
任何提示表示赞赏。在 React 应用程序中,我想在附加其他表单数据和设置标题(理想情况下使用 Axios)之后上传可变数量的文件,并将这些文件发布到 API。
他们文档中的示例使用如下道具:
server="/api"
我想要类似(假代码)的东西:
server={submitImages} <-- this should only happen onclick of some button
在哪里:
submitImages = (fieldName, file) => {
const formData = new FormData()
formData.append(fieldName, file, file.name)
formData.append('foo', this.props.foo)
const docuploadresult = this.props.uploadDocs(formData) <-- a service that lives elsewhere and actually does the POST
docuploadresult.then(result => {
// success
}, error => {
// error
})
}
我的问题是我不明白为什么这需要在一些特殊的配置对象中发生,例如server
,不知道如何在点击时发生这种情况,在任何地方都看不到实际文件。
这可能是我想多了?