vue3 axios Failed to execute ‘createObjectURL‘ on ‘URL‘
时间: 2023-11-11 10:15:39 浏览: 196
vue-axios + vue3-axios Axiso解决跨域访问完整源码
5星 · 资源好评率100%
在你提供的代码中,出现了一个错误信息:"Failed to execute 'createObjectURL' on 'URL'"。这个错误通常是因为在使用createObjectURL时传入的参数不正确导致的。在你的代码中,createObjectURL应该接收一个Blob对象作为参数,但是你传入的是一个Response对象。这可能是因为你在使用axios时没有正确设置responseType。
为了解决这个问题,你可以在axios的配置中添加responseType:'blob'来告诉axios返回的数据类型是Blob。这样,你就可以正确地将返回的数据传递给createObjectURL。
下面是一个修改后的示例代码:
```javascript
this.$axios.post('/setting/uploadUserImg', form, { responseType: 'blob' })
.then((res) => {
let blob = new Blob([res.data]);
let url = window.URL.createObjectURL(blob);
this.userInfo.userImgUrl = url;
});
```
通过设置responseType为'blob',axios会将返回的数据解析成Blob对象,然后你就可以正常地使用createObjectURL了。
希望以上解答能帮到你,如果还有其他问题,请随时提问。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [【前端】采坑合集](https://blog.csdn.net/lorogy/article/details/127083962)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *3* [Vue Flask mysql图片存储与显示](https://blog.csdn.net/Thomas_cannon/article/details/128967634)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文