Invalid prop: type check failed for prop "data". Expected Object, got FormData
时间: 2023-08-18 22:13:03 浏览: 159
在el-upload组件中,确实使用:data属性传递普通的JavaScript对象作为请求数据,而不是FormData对象。如果您想要将FormData对象传递给后端Django接口,可以使用自定义的headers来实现。
以下是一个示例代码:
```html
<template>
<div>
<el-upload
action="/your-upload-url/"
:before-upload="handleBeforeUpload"
:on-success="handleSuccess"
:headers="uploadHeaders"
>
<el-button slot="trigger" size="small" type="primary">点击上传</el-button>
</el-upload>
</div>
</template>
<script>
export default {
data() {
return {
uploadHeaders: {} // 自定义headers
};
},
methods: {
handleBeforeUpload(file) {
const formData = new FormData();
formData.append('file', file);
// 设置自定义headers
this.uploadHeaders = {
'Content-Type': 'multipart/form-data' // 设置Content-Type为multipart/form-data
};
return formData;
},
handleSuccess(response, file, fileList) {
// 处理上传成功的回调
}
}
};
</script>
```
在上面的代码中,我们使用:before-upload属性来指定一个处理函数handleBeforeUpload。在该函数中,我们创建一个新的FormData对象,并将文件添加到其中。然后,我们设置自定义的headers,将Content-Type设置为multipart/form-data。
最后,我们将FormData对象返回,el-upload组件将使用它进行上传。
请根据您的实际需求修改handleBeforeUpload函数以及处理上传成功的回调函数handleSuccess。
阅读全文