vue使用axios使用二进制流下载文件

博客展示了在VUE中使用axios下载二进制流文件的代码。通过axios发送post请求,设置返回数据类型为blob,处理返回的文件流,针对非IE和IE10+浏览器分别给出下载方法,还提供了AXIOS中文文档链接。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

exportData () {
const form = this.getSearchForm() // 要发送到后台的数据
axios({ // 用axios发送post请求
method: ‘post’,
url: ‘/user/12345’, // 请求地址
data: form, // 参数
responseType: ‘blob’ // 表明返回服务器返回的数据类型
})
.then((res) => { // 处理返回的文件流
const content = res
const blob = new Blob([content])
const fileName = ‘123.jpg’
if (‘download’ in document.createElement(‘a’)) { // 非IE下载
const elink = document.createElement(‘a’)
elink.download = fileName
elink.style.display = ‘none’
elink.href = URL.createObjectURL(blob)
document.body.appendChild(elink)
elink.click()
URL.revokeObjectURL(elink.href) // 释放URL 对象
document.body.removeChild(elink)
} else { // IE10+下载
navigator.msSaveBlob(blob, fileName)
}
})
}

如果实在不懂 可以查看 AXIOS 中文文档 https://www.kancloud.cn/yunye/axios/234845

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值