如果后端直接返回的流文件 需要用到这个
fetch(
'/abcd/efg/opq/down',
{
method:'POST',
headers:{
'Content-Type':'application/x-www-form-urlencoded',
},
// content-Type 我这个提交方式是表单提交 , 一般是json,
responseType: 'blob',
// responseType 必填 ,为blob 最后这样处理
body: formData,
// 这是我的表单参数.
},
).then( response => {
// 这一段可以不用配置, 如果写公用请求可以加上,返回这种格式的话把下面的放到判断里面,
// 因为返回的响应头是application/vnd.ms-excel;charset=utf-8' 这种格式的 。excel表格
if (
response.headers.get('Content-Type').toLowerCase() ===
'application/vnd.ms-excel;charset=utf-8'
){
}
// 文件名字如果后端没有返回给你就自己写, 这个是返回的名字 decodeURIComponent 是把浏览器的编译//的乱码改成文字
let filename = decodeURIComponent(response.headers.get('content-disposition').split("filename=")[1])
response.blob()
.then(blob => {
let bl = new Blob([blob], {
type: "application/vnd.ms-excel;charset=utf-8",
})
// 在这里处理一下blob ,type加上application/vnd.ms-excel;charset=utf-8" ,因为我的后端返回为的是json 所以我设置了type 。
// 下面就是创建一个a标签 然后获取一下url 打开就完事
let a = document.createElement('a');
let url = window.URL.createObjectURL(bl);
let fileName = filename;
a.href = url;
a.download = fileName;
a.click();
window.URL.revokeObjectURL(url);
})