后端输出流文件时,浏览器不保存文件,不弹下载框

8 篇文章 0 订阅

实践得知:通过ajax请求后端时,浏览器不会保存文件。因为ajax不支持返回二进制流。 我用的是axios也不行

解决方法:

      //导出
      xxx(){
          console.log(this.data2)
          Vue.prototype.$axios({
              xhrFields: {
                  withCredentials: false
              },
              method:'post',
              url: 你的apiurl,
              responseType: 'blob',//不加这个responseType时,下载的文件可能乱码
              data:this.data2
          })
              .then((res) =>{
              console.log(res)
              let blob = new Blob([res.data]);
              let downloadElement = document.createElement("a");
              let href = window.URL.createObjectURL(blob); //创建下载的链接
              downloadElement.href = href;
              downloadElement.download = 'report.zip'; //下载后文件名
              document.body.appendChild(downloadElement);
              downloadElement.click(); //点击下载
              document.body.removeChild(downloadElement); //下载完成移除元素
              window.URL.revokeObjectURL(href); //释放掉blob对象
          })
      },

这样就会把后端返回的流转换为blob 然后下载

具体这个“ responseType: ‘blob’ ”代表什么:

参考文献:http://www.axios-js.com/zh-cn/docs/index.html

表示服务器响应的数据类型,可以是 ‘arraybuffer’, ‘blob’, ‘document’, ‘json’, ‘text’, ‘stream’。

当然里面的东西,请大家自己参考实际当中自行修改。

参考链接:https://www.cnblogs.com/shangguancn/p/14789220.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值