后端返回文件流,前端进行文件导出

在开发导出功能时,后端可能返回一的不是json文件地址而是一个二进制的文件流,当我们遇到这个问题我们需要怎么处理呢?(如图是我请求接口返回的文件流)

当导出接口请求正常时,我们前端会收到一个文件流如下图

我们在请求的接口加上一个配置,将文件转为blob    responseType:'blob',

export function taskExport(data) {
  return request({
    url: `/deadwood/wtask/export`,
    method: 'post',
    responseType:'blob',
    data:data
  })
}

接口返回的数据如下图

 将获取的blob进行处理

const blob = new Blob([res.data])

完整代码如下

      //taskExport 是接口

        taskExport(this.searchform).then(res=>{
        const blob = new Blob([res.data])
        const fileName = '文件名称'+ '.xlsx'
        if (window.navigator.msSaveOrOpenBlob) {
          navigator.msSaveBlob(blob, fileName)
        } else {
          const link = document.createElement('a')
          link.href = window.URL.createObjectURL(blob)
          link.download = fileName
          link.click() 
          window.URL.revokeObjectURL(link.href) // 释放 URL 对象
        }
        console.log(res)
      }).catch((error) => {
        console.log(error)
      })

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值