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

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

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


设置成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的文件来,你们根据需求换啊

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容