Vue前端接收后台二进制文件的方式

这篇博客介绍了两种HTTP请求方式在处理PDF下载时的应用。对于简单的GET请求,展示了一个使用URL直接加载PDF的例子;而对于POST请求或参数较多的情况,通过axios库发送POST请求,并在响应后处理blob数据以实现PDF文件的下载。
摘要由CSDN通过智能技术生成

1.如果是是get请求,且参数只有很少,例如:

location.href = `${process.env.VUE_APP_API_BASE_URL}xxx/xxxx/printOrderPdf?id=${this.baseInfo.id}`
 

2.如果是post请求,或者参数很多则:
 

this.$http({
 method: 'post',
 url: 'xxx/xxx/printOrderPdf',
 data:this.pdfParams,//查询所需参数
 responseType: 'blob'
}).then((resp) => {
 if (resp.status === 200) {
  let blob = new Blob([resp.data])
  let elm = document.createElement('a');
  //创建下载的链接
  let href = window.URL.createObjectURL(blob); 
  elm.href = href;
  elm.download = 'XXXX.PDF'; 
  document.body.appendChild(elm);
  elm.click(); 
  //下载完成移除元素
  document.body.removeChild(elm);
 //释放掉blob对象
  window.URL.revokeObjectURL(href); 
 } else {
  this.visibleAlert = true
  this.visibleAlertText = "导出PDF失败"
 }
}).catch((error) => {
 console.log(error)
})

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值