前端post下载实现

本文介绍了一种使用JavaScript进行Excel文件导出的方法。通过将数据转换为Blob对象,并利用浏览器的下载机制,实现了从Web应用直接导出数据到Excel文件的功能。代码中包含了对响应类型、文件名解析及不同浏览器兼容性的处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >


```javascript
exportService(url,params){
   url = this.budService.getBaseUrl()+url;
   return this.http.post(url,params,{responseType:'arraybuffer',observe:'response'}).toPromise().then(res=>{
   const blob=new Blob([res.body],{type:'application/vnd.ms-excel'});
   if(res.headers.get('Content-disposition')){
      const fileName=decodeURI(res.headers.get('Content-disposition').split('filename=')[1]);
      if(window.navigator.msSaveOrOpenBlob){
         navigator.msSaveBlob(blob,fileName)
      }else{
          const link = document.createElement('a');
	      link.setAttribute('href',window.URL.createObjectURL(blob));
	      link.setAttribute('download',fileName);
	      link.style.visibility='hidden';
	      document.body.appendChild(link);
	      link.click();
	      document.body.removeChild(link);
      }
    } else {
        var encodedString = utf8ArrayToStr(new Uint8Array(res.body));
        var obj = JSON.parse(encodedString);
        if(obj.code==='SYS-9000'){
          /**拒绝访问  停留3秒*/
          this.message.error(`后台提示:${obj.message}`,{gmDuration:3000});
        }else{
          this.modalService.error({
            title:'后台错误提示',
            content:`${obj.message}`
          })
        }
    }
 })
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值