vue+axios实现文件下载——请求的responseType为blob

vue+axios实现文件下载

 

功能:点击导出按钮,提交请求,下载excel文件;

 

第一步:跟后端童鞋确认交付的接口的response header设置了

以及返回了文件流。

 

第二步:修改axios请求的responseType为blob,以post请求为例:

复制代码
复制代码
axios({
    method: 'post',
    url: 'api/user/',
    data: {
        firstName: 'Fred',
        lastName: 'Flintstone'
    },
    responseType: 'blob'
}).then(response => {
    this.download(response)
}).catch((error) => {

})
复制代码
复制代码

 

第三步:请求成功,拿到response后,调用download函数(创建a标签,设置download属性,插入到文档中并click)

复制代码
复制代码
methods: {
    // 下载文件
    download (data) {
        if (!data) {
            return
        }
        let url = window.URL.createObjectURL(new Blob([data]))
        let link = document.createElement('a')
        link.style.display = 'none'
        link.href = url
        link.setAttribute('download', 'excel.xlsx')
        
        document.body.appendChild(link)
        link.click()
    }
}
复制代码
复制代码

 

posted @   PanPan003  阅读(5289)  评论(0编辑  收藏  举报
编辑推荐:
· 没有源码,如何修改代码逻辑?
· 一个奇形怪状的面试题:Bean中的CHM要不要加volatile?
· [.NET]调用本地 Deepseek 模型
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· .NET Core 托管堆内存泄露/CPU异常的常见思路
阅读排行:
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· DeepSeek R1 简明指南:架构、训练、本地部署及硬件要求
· 没有源码,如何修改代码逻辑?
· NetPad:一个.NET开源、跨平台的C#编辑器
· 面试官:你是如何进行SQL调优的?
点击右上角即可分享
微信分享提示