vue 后台接口返回文件流地址的下载

vue 后台接口返回文件流地址的下载_第1张图片

第一次获取这样的数据,无从下手啊,百度吧

其实很简单,首先在axios.post的请求中把默认的 " responseType:‘json’ " 改为" responseType:‘blob’ "; 这块要敲黑板了,我栽在这里了,一直没有修改,所以下载下来的文件打开后一直提示,如图


vue 后台接口返回文件流地址的下载_第2张图片

设置成blob后打开无压力!

然后按正常的请求接口的方式获取到了这个文件流,可能是response.data,也可能直接就是response,这个看你们后端人员如何返回了, 获取到的文件流我们用blob转一下,

let blob = new Blob([res], {type: "application/vnd.ms-excel"}); // res就是接口返回的文件流了

let objectUrl = URL.createObjectURL(blob);

window.location.href = objectUrl;

这样不需要再有其他操作了,直接就可以导出文件了.

忘了,得注意blob里的这个type,要根据你们的需要更换文件类型啊,可以参考一下这个 https://www.cnblogs.com/yjmBlogs/p/9493726.html , 我需要导出的是列表数据,所以选的是’application/vnd.ms-excel’,就会导出.xls的文件来,你们根据需求换啊

你可能感兴趣的:(vue 后台接口返回文件流地址的下载)