vue+axios 实现Excel下载

这篇博客介绍了如何在Vue前端使用axios实现Excel文件的下载,包括设置axios全局参数,处理responseType为'blob'的数据,以及模拟<a>标签进行文件下载的操作,解决了无法设置表头和传递参数的问题。

以前写过关于Springboot提供Excel文件下载的博客:SpringBoot 使用POI进行Excel下载_兮川的博客-优快云博客 ,当点击下载的api地址时,就可以直接下载,或我们在前端页面直接使用<a>标签,href指向下载地址,我们也可以进行下载。

但是....,<a>标签无法进行设置表头,也无法进行参数的传递,确实是一个头疼的问题。此时,我们就需要使用axios进行文件的下载操作。

1.修改后端response的头部

response.setHeader("Content-type","application/octet-stream");  //将文件设置为流的形式进行传递,返回的是二进制形式
response.setCharacterEncoding("UTF-8");
response.setHeader("Content-Disposition","attachment;filename="+new String("工资模版".getBytes("UTF-8"),"ISO-8859-1")+".xls");

2.axios代码

设置我们想要的axios的global参数:

    axios.defaults.baseURL = 'http://localhost:7000/micro';
    axios.defaults.headers.common['school_id'] = "1111";
    axios.defaults.headers.common['account_id'] = "1001";
    axios.defaults.headers.post['conte
使用Vue和Spring MVC实现Excel导出功能,可参考以下步骤与代码示例: ### 后端(Spring MVC) 在Spring MVC里,要保证注解使用`@Controller`,不能添加`@ResponseBody`,因为返回的是流而非JSON。以下是一个简单示例: ```java import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.GetMapping; import javax.servlet.http.HttpServletResponse; import java.io.OutputStream; import java.net.URLEncoder; @Controller public class ExcelExportController { @GetMapping("/exportExcel") public void exportExcel(HttpServletResponse response) throws Exception { // 设置响应头 response.setContentType("application/vnd.ms-excel"); response.setCharacterEncoding("utf-8"); String fileName = URLEncoder.encode("exported_file", "UTF-8"); response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xls"); // 模拟写入Excel数据,这里可以使用POI等库进行实际的Excel操作 OutputStream outputStream = response.getOutputStream(); String excelData = "Sample Excel Data"; outputStream.write(excelData.getBytes()); outputStream.flush(); outputStream.close(); } } ``` ### 前端(Vue) 基于Vue,使用axios调用后端接口,实现下载文件的方法: ```javascript import axios from 'axios'; export function exportExcel(filename, res) { const link = document.createElement('a'); let blob = new Blob([res.data], { type: 'application/vnd.ms-excel' }); link.style.display = 'none'; link.href = URL.createObjectURL(blob); let num = ''; for (let i = 0; i < 10; i++) { num += Math.ceil(Math.random() * 10); } link.setAttribute('download', filename + '.xls'); document.body.appendChild(link); link.click(); document.body.removeChild(link); } // 在Vue组件中调用 export default { methods: { async downloadExcel() { try { const response = await axios.get('/exportExcel', { responseType: 'blob' }); exportExcel('exported_file', response); } catch (error) { console.error('导出Excel失败:', error); } } } } ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值