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'
  })
}

根据提供的引用内容,可以看出在Vue中实现导出Excel文件后端操作是通过发送请求获取文件流,并将文件流转换为可下载的链接。具体实现步骤如下: 1. 在后端定义一个接口,用于导出Excel文件。在该接口中,设置响应类型为`application/vnd.ms-excel`,确保返回的是Excel文件格式。同时,将文件流作为响应返回前端。 2. 在前端Vue组件中,定义一个导出Excel的方法,例如`exportExcelFn()`。在该方法中,调用后端接口获取文件流,并将文件流转换为可下载的链接。 3. 在前端Vue组件中,使用`<el-button>`标签绑定导出Excel的方法,例如`<el-button @click="exportExcelFn">导出Excel表格</el-button>`。 4. 在导出Excel的方法中,使用`URL.createObjectURL()`方法将文件流转换为可下载的链接,并设置下载文件名。 5. 创建一个`<a>`标签,将可下载的链接赋值给`href`属性,并设置`download`属性为要下载文件名。 6. 将`<a>`标签添加到页面的`<body>`元素中,并模拟点击该链接,实现文件下载。 综上所述,Vue导出Excel文件后端操作可以通过以上步骤实现。 #### 引用[.reference_title] - *1* [前端导出excel文件 vue导出文件后端传流导出excel文件](https://blog.csdn.net/robotkirin/article/details/122243655)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [Vue实现excel文件的导出功能(后端直接返回文件流)](https://blog.csdn.net/qq_41954585/article/details/124961373)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

五分钱嘀Love

一起学习,一起努力。

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

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

打赏作者

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

抵扣说明:

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

余额充值