vue下载excel文件,(后端返回的是文件流)

1、通过后端给的文件地址下载

window.location.href=URL

window.open(URL)

区别:

window.location:当前页跳转,也就是重新定位当前页;只能在网站中打开本网站的网页。

window.open:在新窗口中打开链接;可以在网站上打开另外一个网站的地址

2、通过 js-file-download 插件

npm install js-file-download --S
import fileDownload from 'js-file-download'
  
axios.get(`downLoadExcel/template`, {
        responseType: 'blob' //返回的数据类型
    })
    .then(res => {
        fileDownload(res.data, this.fileName)
    })

3、使用fetch下载

downFile() {
    fetch('http://10.190.156.103:3000/api/deviceList/downLoadExcel', {
        method: 'GET',
        headers: new Headers({
            'Authorization': Cookie.get('Authorization') 
        }),
    })
   .then(res => res.blob())
   .then(data => {
        const blobUrl = window.URL.createObjectURL(data);
        const a = document.createElement('a');
        a.download = this.fileName+'.xlsx';
        a.href = blobUrl;
        a.click();
});
},

4、vue通过 a 标签的 download 属性结合 blob 构造函数下载excel文件

download() {
      aoiTemplateExport().then((res) => {
        const url = window.URL.createObjectURL(new Blob([res], { type: 'application/vnd.ms-excel;charset=utf-8' }))
        const link = document.createElement('a')
        link.style.display = 'none'
        link.href = url
        link.setAttribute('download', '数据模板.xlsx')
        document.body.appendChild(link)
        link.click()
      })
  }

js:

export function aoiTemplateExport() {
  return request({
    url: '',
    method: 'get',
    responseType: 'blob'
  })
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

五分钱嘀Love

一起学习,一起努力。

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

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

打赏作者

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

抵扣说明:

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

余额充值