EasyExcel快速实现前后端导出

文章讲述了作者在后端使用EasyExcel将数据写入Excel文件,并通过设置响应头和编码避免中文乱码。前端则通过fetchAPI发送GET请求,设置响应类型为Blob,以临时链接模拟点击下载Excel文件的过程。
摘要由CSDN通过智能技术生成

试了很多别人写的方法,下载下来就是格式损坏,没办法只能自己来了,拒绝花里胡哨,一切从简。

后端

List<AlarmH> alarmHS = easyExcelService.simpleWrite();
            response.setContentType("application/vnd.ms-excel");
            response.setCharacterEncoding("utf-8");
            // 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
            String fileName = URLEncoder.encode("报警信息", "UTF-8");
            response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".xlsx");
            EasyExcel.write(response.getOutputStream(), AlarmH.class)
                    .sheet("仪器")
                    .doWrite(alarmHS);

前端

下面代码使用fetch函数发送GET请求并设置响应类型为blob,以便获取导出的Excel文件。然后,使用URL.createObjectURL()方法创建临时链接,并通过元素的click()方法模拟点击进行下载。最后,使用URL.revokeObjectURL()释放资源。

function downloadExcel() {
		  fetch('http://127.0.0.1:8081/excel/alarmHExcel', {
		    method: 'GET',
		    responseType: 'blob' // 设置响应类型为Blob
		  })
		    .then(response => response.blob())
		    .then(blob => {
		      const url = window.URL.createObjectURL(blob);
		      const a = document.createElement('a');
		      a.href = url;
		      a.download = '报警信息.xlsx';
		      a.click();
		      window.URL.revokeObjectURL(url);
		    })
		    .catch(error => {
		      console.error('下载失败:', error);
		    });
		}
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值