前端接受后端返回的文件流,并且下载文件自定义文件名

本文介绍了一种使用axios请求以文件形式返回数据的方法,通过设置responseType为'blob',并利用Blob对象和HTML5的a标签实现文件的下载功能。此方法适用于下载Excel等文件格式。

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

以文件方式返回:

请求属性:responseType: 'blob'

 

 

示例代码:

request.post('/demo/download', {
      params: {
        fileName: 'aaa'
      },
      responseType: 'blob'
    }).then(res => {
      if (res) {
        
        let blob = new Blob([res], { type: 'application/vnd.ms-excel' })

        const link = document.createElement("a")
        link.href = window.URL.createObjectURL(blob)
        link.download = '模版.xlsx'
        // fix Firefox
        link.style.display = "none"
        document.body.appendChild(link)
        link.click()
        document.body.removeChild(link)
        window.URL.revokeObjectURL(link.href)
      } else {
        notification.error({
          message: '下载模版失败'
        })
      }
    })

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值