vue实现下载字节流文件

需求:后端接口传过来一个字节流,前端通过浏览器下载到本地

接口响应内容 be like

实现:

html部分:

<!-- 设置一个按钮点击下载 -->
<el-button @click="download(id)"></el-button>

js部分:

// 伪代码
<script>
import axios from 'axios'

export default {
    methods: {
     // 下载
     download(val) {
      axios({
        method: 'get',
        url: 'j接口地址?参数=' + val,
        responseType: 'blob' //重点!一定要设置responseType为blob
      })
        .then(res => {
           //构造blob对象,type是文件类型,详情可以参阅blob文件类型
          let blob = new Blob([res.data], { type: 'application/zip' }) //我是下载zip压缩包
          let url = window.URL.createObjectURL(blob) //生成下载链接
          const link = document.createElement('a') //创建超链接a用于文件下载
          link.href = url //赋值下载路径
          link.target = '_blank' //打开新窗口下载,不设置则为在本窗口下载
          link.download = `${ '文件名' + val }.zip` //下载的文件名称(不设置就会随机生成)
          link.click() //点击超链接触发下载
          URL.revokeObjectURL(url) //释放URL
          this.$message.success('下载完成')
        })
        .catch(error => this.$message.error('下载失败'))
     }
    }
}

附:blob接口文档

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值