fetch 处理后端流文件 返回直接打开下载

如果后端直接返回的流文件 需要用到这个

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);
      })

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值