我正在尝试使用对象内的 Axios 上传图像。我可以使用获取文件new FormData()并将其放入对象中,但提交的图像是空的。如何将对象中的文件与其他 JSON 数据结合起来上传?
import React, { useState } from 'react';
import axios from 'axios';
function UploadFiles() {
const [submitFile, setSubmitFile] = useState({});
const handleChange = e => {
setSubmitFile(e.target.files[0]);
};
const handleSubmit = () => {
const formData = new FormData();
formData.append('document', submitFile);
formData.append('Answer_name', 'image');
formData.append('Document', true);
formData.append('Answer', 'Got some data');
console.log(submitData) // I get formData data
const submitData = {
UUID_Formulier: '117F994F-F803-7249-91E9-EE1E7B691DFF',
answers: [formData], // this will be an empty object on calling axios.post
};
axios
.post('/submit', submitData, {
headers: {
'Content-Type': 'multipart/form-data',
},
})
.then(() => {
console.log('success');
})
.catch(() => {
console.log('failed error');
});
};
return (
<div>
<input type="file" name="image" onChange={handleChange} />
<button onClick={handleSubmit}>Submit</button>
</div>
);
}
图像必须放置在答案数组中。当我将 FormData 放入答案数组时,它是一个空对象。如何将文件 formData 放入 JSON 对象或数组然后提交全部?
使用方括号表示法不会创建数组,而是创建字符串,如下所示。
幕布斯7119047
斯蒂芬大帝
相关分类