后端返回数据是二进制流,下载表格正常但打开后出现空白

使用原生请求下载后端返回的二进制流可以解决空白问题,直接看代码:

// 下载函数
export async function downloadFn(response: any, filename: string) {
  //2.创建FileReader对象,用于读取文件
  const reader = new FileReader();
  //3.将文件读取为文本
  reader.readAsText(response, 'utf-8');
  //4.处理读取事件
  //4.1读取完成事件,获取数据
  reader.onload = (e: any) => {
    console.log(e, 123456);
    // 给予提示,返回为json
    if (e.currentTarget.result.indexOf('"code":"0"') !== -1) {
      const handledRes = JSON.parse(e.currentTarget.result);
      message.error(handledRes?.msg);
    } else {
      // 成功,返回的是文件流
      const url = window.URL.createObjectURL(response);
      const link = document.createElement('a');
      link.style.display = 'none';
      link.href = url;
      link.setAttribute('download', filename);
      document.body.appendChild(link);
      link.click();
      document.body.removeChild(link);
    }
  };
}

// 用这种原生请求下载后端返回的二进制流打开就不会出现空白
export async function downloadFileStreamFun(reqUrl: string, filename: string) {
  return new Promise(function (resolve, reject) {
    const xhr = new XMLHttpRequest();
    xhr.open('get', reqUrl, true);
    xhr.responseType = 'blob';
    xhr.onload = function () {
      console.log(xhr, '打印构造函数xhr');
      //即使是404也会进入这个相应函数,所以需要检测状态
      if (xhr.status == 200) {
        //完成许诺,返回响应文本
        resolve(xhr.response);
        downloadFn(xhr.response, filename);
      } else {
        //完成未完成,返回错误
        reject(Error(xhr.statusText));
      }
    };
    xhr.send();
  });
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值