
一.背景
IE或Edge浏览器下,在导出(下载)的时候,有时会返回blob文件流的数据,而不是返回URL地址。此时表现为,能够通过单独访问URL可导出文件,但做为http或https请求时,却无法导出(下载)文件。这主要是因为IE或Edge浏览器挂载文件的方式与Chrome浏览器有所不同。下面对于这种场景,谈谈其具体应用。
二.应用
第一步:在window挂载下载文件的方法
1 | window.downFile = function(resBlob,fileName,fileType='.xls',target='_self') { |
第二步:在使用 axios
请求的时候,在参数中加入responseType: 'blob'
1 | const res = await this.$http({data: {},responseType: 'blob'}) |
三.兼容
IE/Edge/Chrome 浏览器,使用 window.URL.createObjectURL
创建 Blob
链接的区别,可通过在控制台输入window.navigator.userAgent
查看浏览器的版本。
1.IE生成不带域名的 blob:链接
1 | //浏览器版本 |
2.Edge生成带有当前域名的标准 blob:链接
, 却下载不了,需要使用 window.navigator.msSaveOrOpenBlob
方法创建 blob 链接方可下载
1 | Mozilla/5.0 (Macintosh; Intel Mac OS X 11_1_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.141 Safari/537.36 Edg/87.0.664.75 |
3.Chrome生成带有当前域名的标准 blob:链接
1 | Mozilla/5.0 (Macintosh; Intel Mac OS X 11_1_0) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.141 Safari/537.36 |