以前的列表导出都是下载的插件自己导出的,现在要求从后台导出,然后后台接口返回的是文件流,如下图
在这里插入图片描述

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

其实很简单,首先在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的文件来,你们根据需求换啊

Logo

前往低代码交流专区

更多推荐