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

JavaScript下载excel文件

文章目录

  • 通过链接下载
    • a标签
    • 下载方法
    • 注意
  • 获取文件流
    • 请求体配置
    • 下载文件流
  • 总结


通过链接下载

a标签

对于已知地址的目标文件,前端可以使用 a标签 来直接下载,使用a标签下载使用到两个属性

  • download:下载文件名
  • href:目标文件下载链接
<a href="xxx/xxx/a.xlsx" download="a.xlsx">点击下载图片</a>

下载方法

使用时给触发的div绑定事件

  const download = async () => {const url = 'https://xx.com/xx/xx/a.xlsx'const fileName = 'a.xls'let a = document.createElement("a");a.download = fileName;a.href = url;document.body.append(a); // 修复firefox中无法触发clicka.click();URL.revokeObjectURL(a.href);a.remove();}

注意

a标签的下载只能使用get请求,且无法在请求体中添加header信息

获取文件流

请求体配置

axios({url: 'https://xxx.com/xxx/xxx',method: 'get',responseType: 'blob',}).

请求方法可用post或者get,responseType一般需要设置为 blob 或者 arraybuffer

下载文件流

  • 封装下载函数
export const downloadFileByBlob = (fileData, fileName, ext = 'xlsx') => {const blob = new Blob([fileData], {type: docMimeTypes[ext],});console.log('fileData---',fileData)console.log('blob---',blob)const objectUrl = window.URL.createObjectURL(blob);const link = document.createElement('a');link.href = objectUrl;link.setAttribute('download', fileName);document.body.appendChild(link);link.click();link.remove();window.URL.revokeObjectURL(objectUrl); // 文件下载后,释放blob对象
};
  • 下载函数使用
	  const res = await downLoadFile(param)console.log('downLoadFile-->', res)downloadFileByBlob(res.data, '下载文件') // 数据流是个Blob对象

打印如下👇
在这里插入图片描述

在这里插入图片描述

总结

JavaScript下载文件

  • 通过链接下载

  • 获取文件流

http://www.lryc.cn/news/141668.html

相关文章:

  • 研磨设计模式day12命令模式
  • 设计模式 06 适配器模式
  • UE4/5Niagara粒子特效之Niagara_Particles官方案例:3.3->4.3
  • 数据结构队列的实现
  • Gti的基本介绍和使用方式
  • 剑指Offer 24-反转链表
  • 小研究 - Java虚拟机即时编译器的一种实现原理
  • 【LeetCode】416.分割等和子集
  • go vet中的那些检测项
  • Qt 自定义菜单、右键菜单
  • VScode 编辑器报错: ‘HelloWorld‘ is declared but its value is never read.
  • 如何使用LLM实现文本自动生成视频
  • Rust处理JSON
  • Python如何操作网络爬虫
  • linux文件复制覆盖命令
  • modbus概览
  • KMP算法开荒
  • XXL-JOB(2)
  • Linux常用命令_网络命令、关机重启命令
  • 用Cmake build OpenCV后,在VS中查看OpenCV源码的方法(环境VS2022+openCV4.8.0) Part I
  • 如何使用Docker搭建ZooKeepe集群
  • 【javaweb】学习日记Day3 - Ajax 前后端分离开发 入门
  • SQL注入漏洞复现:探索不同类型的注入攻击方法
  • 大彩串口屏使用记录
  • Qt http 的认证方式以及简单实现
  • 【图像分割】实现snake模型的活动轮廓模型以进行图像分割研究(Matlab代码实现)
  • 【MongoDB系列】1.MongoDB 6.x 在 Windows 和 Linux 下的安装教程(详细)
  • 5.网络原理之初识
  • 【Linux】进程状态|僵尸进程|孤儿进程
  • ASEMI快恢复二极管APT80DQ60BG特点应用