当前位置: 首页 > article >正文

前端通过new Blob下载文档流(下载zip或excel)

当后端返回这样的预览:

前端该如何下载呢?首先在axios请求里,加入第三个参数{ responseType: ‘blob’ }。

proxy.$post(url, params, { responseType: 'blob' }).then((res)=>{
  downloadFormat(res)
});

然后在一个函数里处理返回,创建a标签来下载

// 这里是下载zip文件的处理

const downloadFormat = (res) => {
  if (!res.data) {
    return;
  }
  let stringName = res.headers['content-disposition'].split(';')[1];// 一般来说,文件名字后端都在返回头里,前后端可以约定文件名前用 @ 符号分隔,便于取值,用其他符号也可以。
  let fileName = stringName.split('=')[1];// 获取到了后缀名
  const blob = new Blob([res.data], { type: 'application/zip' }); // application/zip就是设置下载类型,需要设置什么类型可在标题二处查看,
  const url = window.URL.createObjectURL(blob); // 设置路径
  const link = window.document.createElement('a'); // 创建a标签
  link.href = url;
  link.setAttribute('download', fileName); // 给下载后的文件命名
  link.style.display = 'none';
  link.click();
  URL.revokeObjectURL(url); // 释放内存
}

// 这里是下载excel的处理, 可根据需要传文件名和文件类型

const downloadFormat = (res, fileName, fileType) => {

  let stringName = res.headers['content-disposition'].split(';')[1];
  let fileName = stringName.split('=')[1];

  const blob = new Blob([res.data], { type: fileType ?? 'application/vnd.ms-excel' });

  // application/vnd.ms-excel 表示.xls文件
  // application/vnd.openxmlformats-officedocument.spreadsheetml.sheet 表示.xlsx文件
  
  // 也可以不写type,反正是下载,又不是上传。

  if (!blob) {
    return;
  }

  const url = window.URL.createObjectURL(blob);

  const link = document.createElement('a');
  link.style.display = 'none';
  link.href = url;
  link.setAttribute('download', fileName);

  document.body.appendChild(link);
  link.click();
  window.URL.revokeObjectURL(url); // 为了性能和内存使用状况,应该在适当的时候释放url
}

还有一种get方式通过window.location.href来下载文件,在浏览器F12网络里预览和响应没有返回值,写法如下

window.location.href = '/api/exportData?ids=' + 拼接的参数

其中/api被代理转发了,在vite.config.js文件里config.server.proxy对象配置如下:

"/api": {
  target: "https://test.XXX.net",
  secure: false,
  changeOrigin: true,
}

// 真实请求地址含api,并未被reWrite为空

http://www.kler.cn/a/446840.html

相关文章:

  • RabbitMQ消息可靠性保证机制7--可靠性分析-rabbitmq_tracing插件
  • 【网络安全】用 Frida 修改软件为你所用
  • 大数据机器学习算法和计算机视觉应用07:机器学习
  • uniapp Native.js 调用安卓arr原生service
  • UE5喷涂功能
  • Layui table不使用url属性结合laypage组件实现动态分页
  • uniapp小程序样式穿透
  • 深度学习实战车辆目标跟踪【bytetrack/deepsort】
  • notepad++快捷键-多行编辑中如何使所有行的光标都向后移动一个单词的长度(每行单词长度不一定一致)
  • cenos如何升级git到2以上版本
  • centos7下docker 容器实现redis主从同步
  • 智慧农业云平台与水肥一体化:道品科技引领农业现代化新潮流
  • 玩转树莓派Pico(19): 迷你气象站5——软件整合
  • 代码随想录第52天
  • 【数据分析】层次贝叶斯
  • 电子应用设计方案-64:智能窗帘系统方案设计
  • React与Vue的区别(相同点和不同点)
  • 一个签名笔迹量化分析专家辅助系统
  • 数据结构:B树与B+树
  • React 事件机制和原生 DOM 事件流有什么区别
  • 源码编译llama.cpp for android
  • linux下网络编程socketselectepoll的底层实现原理
  • js常用方法之: 预览大图(uniapp原生方法封装)
  • 机器学习《西瓜书》学习笔记《待续》
  • git分支管理及策略
  • HIPT论文阅读