Vue—文件下载的实现

Vue实现文件下载

首先要分清楚后端返回的是文件流还是直接触发链接就进行下载。
如果是直接触发链接下载的话,那就很简单了,将返回的url给a标签的url属性既可。

如果是文件流的话,那就需要前端再做一次处理,才能进行下载。

  1. 触发下载的接口,要在axios设置responseType = ‘blob’
    这个参考官方文档https://github.com/axios/axios
  2. 写一个接受文件流的函数
// 接受后端blob文件流 下载
// blob 文件流 fileName 文件名称
function downFiles(blob, fileName) {
    let link = document.createElement('a')
    link.href = window.URL.createObjectURL(blob)
    link.download = fileName
    link.click()
    window.URL.revokeObjectURL(link.href)
}
 
  1. 发送请求的回调函数里,也要做一些处理,比如说我要触发xx/down接口
api("down", formData, "post", "blob").then(function(res) {
                let blob = new Blob([res.data], {
                    type: '*'
                })
                let fileName = '交易列表'
                _this.$tool.downFiles(blob, fileName)
                _this.isDown = false
            })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值