axios发送异步请求文件,并下载文件到本地

背景:业务上有这样一个需求:

一个列表数据,通过条件查询筛选出目标列表数据,然后将这些目标列表数据导出到本地

后端提供了一个post的异步请求接口,并返回了文件(此处后端逻辑应该是接收到查询条件,去数据库中筛选目标数据,并生成一个excel表格,返回给前端)

axios发送异步post请求常见方式:

axios.request({
  url: '/***/getFile',
  method: 'post',
  data: {page:1},  // 查询文件时的请求参数
})

普通请求发出去,我们接收到返回的数据,一般是一个json的数据结构,拿到这些数据进行处理。


那么此时按照普通post请求发出去,得到的返回结果大概长这样
在这里插入图片描述
看到这样的返回数据,不知道的还以为是乱码呢,但你想一下,excel的表格在浏览器上肯定是打不开的,出现这样的结果也是情理之中。

那么我们应该怎样实现发送了这个异步请求,拿到数据并下载excel文件到本地呢?

要达到我们想要的效果,首先修改一下请求参数

  1. 将文件转为blob格式,方便前端做对应处理
axios.request({
   url: '/api/**/getFiles',
   method: 'post',   // 以post请求为例
   data: {page: 1, pageSize: 20, age: 20},   // 筛选列表的请求参数
   responseType: 'blob',   // 重要, 限制返回的数据结构为blob格式,方便前端做转换
})
  1. 此时,前端接收到的数据结果为:
    在这里插入图片描述
  2. 前端处理数据
const res = axios.request({
    url: '/api/**/getFiles',
	method: 'post',   // 以post请求为例
	data: {page: 1, pageSize: 20, age: 20},   // 筛选列表的请求参数
	responseType: 'blob', 
}).then(res=>{
	const data = res.data
	let url = window.URL.createObjectURL(data)   // 将二进制文件转化为可访问的url
    var a = document.createElement('a')  
    document.body.appendChild(a)
    a.href = url
    a.download = '宿主列表.xls'
    a.click()   // 模拟点击下载
    window.URL.revokeObjectURL(url)
})
  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值