js/axios/umi-request 根据后端返回的二进制流下载文件

javascript 复制代码
type ResponseType = {
  data: Blob;
  headers: {
    'content-disposition'?: string;
  };
};
// 下载 (创建a标签)
export const downloadBlob = (response: ResponseType) => {
  const blob = response.data; // 获取响应中的 Blob 数据
  const contentDisposition = response.headers['content-disposition'];
  let fileName = ''; // 默认文件名
  if (contentDisposition) {
    // 提取文件名并解码成中文
    const fileNameRegex = /filename=([^;]+)/;
    const fileNameMatch = contentDisposition.match(fileNameRegex);
    fileName = fileNameMatch ? fileNameMatch[1] : '';
    if (fileName) {
      fileName = decodeURIComponent(fileName);
    }
  }
  // 创建 Blob 对象后,你可以根据需要执行文件下载逻辑
  const url = window.URL.createObjectURL(blob);
  const link = document.createElement('a');
  link.href = url;
  link.download = fileName; // 设置下载文件的名称
  link.style.display = 'none';
  document.body.appendChild(link);
  link.click();
  // 清除创建的链接
  window.URL.revokeObjectURL(url);
  document.body.removeChild(link);
};

用法很简单。

javascript 复制代码
  const downLoad= async () => {
    const response = await axios(...);
    //将完整的响应头丢进去即可
    aDownload(response);
  };
相关推荐
TPCloud15 分钟前
快速利用c语言实现线性表(lineList)
c语言·开发语言·线性表·linelist
如意.75921 分钟前
【C++】—— map 与 set 深入浅出:设计原理与应用对比
开发语言·c++
容器( ु⁎ᴗ_ᴗ⁎)ु.。oO1 小时前
java中的定时器
java·开发语言
m0_547486661 小时前
一道C语言关于距离的期末题及答案
c语言·开发语言
蹊黎1 小时前
C++模版初阶
开发语言·c++
山川尔尔_1 小时前
JS手写-this绑定实现
开发语言·javascript·ecmascript
YYDS3141 小时前
C++各类函数评点+详解
开发语言·数据结构·c++·算法·贪心算法·动态规划
薯条不要番茄酱2 小时前
数据结构-5.二叉树
java·开发语言·数据结构
那就可爱多一点点2 小时前
H5页面多个视频如何只同时播放一个?
前端·音视频
YAy173 小时前
CC3学习记录
java·开发语言·学习·网络安全·安全威胁分析