前端接收后台返回的流下载

24 篇文章 1 订阅

1、后台返回的二进制字节流 byte[ ]

{responseType:'arraybuffer} 设置好后端接收返回的格式,一般还有json,buffer,blob

axios.post('url',params,{responseType:'arraybuffer}).then(res=>{
	// 开始处理文件下载 - res.data为文件流
    let src= window.URL.createObjectURL(new Blob([res.data], {
        // 后台传递的文件类型 - 此处我是直接从后台获取的
        // 也可以根据文件类型添加
        type: res.headers['content-type']
    }));
    const link = document.createElement('a');
    link.style.display = 'none';
    link.href = src;
// fileName 文件的名称
    link.setAttribute('download', 'fileName'+Date.now())
    document.body.appendChild(link)
    link.click();
    document.body.removeChild(link);
})

2、后台返回的Base64

这个就没什么了,强大的 a 直接下载就行了,将数据赋给 a.href 就 ok; Base64 直接已经是张图片了,复制到浏览器url地址里直接可以显示;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

#老程

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值