Springboot+Vue 通用版Excel模板下载 简单超实用!几行代码实现项目中的Excel模板下载!

本文主要是介绍Springboot+Vue 通用版Excel模板下载 简单超实用!几行代码实现项目中的Excel模板下载!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

SpringBoot+Vue 实现Excel模板下载

文章目录

    • SpringBoot+Vue 实现Excel模板下载
  • 前言
  • 一、前端代码
  • 二、后端代码
  • 总结 : 如果你觉得文章不错,就给作者点个赞吧!有时间还会给大家分享更多项目中的功能文章!!!!


前言

在企业中我们经常会遇到操作Excel的需求,而模板下载就是必不可少的内容,此文给大家一份通用的下载Excel模板的操作。CV即用!!!!基于Vue.js,其实是通用的,只是前端点击事件的声明方式不同。


废话不多说直接上代码

一、前端代码

  1. 下载按钮 : 主要看onclick绑定的方法,这里我们需要传递一个参数,因为可能不止一个页面需要下载模板,参数主要在后端区分不同的模板。因为我用了点Vue vm为new的Vue对象。
<button type="button" onclick="vm.getExcel('MaBuDuoRKD')" class="miaoshu btn btn-outline-success">下载模板
</button>
  1. JS方法 : 此方法是写在Vue的methods中的,如果你用的不是Vue,写在外面就可以了。此处的type参数就是你上面区分模板的自定义参数。在跳转路径后面加上请求参数就可以了。
 			/*** 功能描述: 下载RKD的Excel模板* author 码不多* date 2021/9/2* param type* return*/getExcel(type){//跳转控制器下载Excelwindow.location.href = "/model/getExcelModel?type=" + type;},

二、后端代码

后端只有这一个控制器类代码!复制即可!注意看下面的判断就是前端传的区分模板的参数type

import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import javax.servlet.http.HttpServletResponse;
import java.io.*;@RequestMapping("/model")
@RestController
public class ModelController {//模板下载@RequestMapping("/getExcelModel")public void getExcelModel(String type, HttpServletResponse response) throws Exception {//定义路径,下面会根据前端方法传的类型而进行判断,区分选择下载的模板,并给path赋值String path = "";if ("MaBuDuoRKD".equals(type))path = "src/main/resources/码不多测试001模板.xlsx";if ("Mabuduo".equals(type))path = "src/main/resources/码不多测试002模板.xlsx";//创建文件对象,传递路径参数File file = new File(path);//获取文件名String filename1 = file.getName();//创建缓冲流InputStream fis = new BufferedInputStream(new FileInputStream(path));byte[] buffer = new byte[fis.available()];//读操作fis.read(buffer);//关流fis.close();//设置响应信息 (响应编码等)response.reset();response.setHeader("Content-Disposition", "attachment;filename=" + new String(filename1.getBytes(), "iso-8859-1"));response.setContentType("application/vnd.ms-excel;charset=UTF-8");response.setHeader("Pragma", "no-cache");response.setHeader("Cache-Control", "no-cache");response.setDateHeader("Expires", 0);//响应输出流OutputStream toClient = new BufferedOutputStream(response.getOutputStream());//写操作toClient.write(buffer);//刷新toClient.flush();//关流toClient.close();}
}

三、Excel模板的存储位置 : 注意我的路径为src/main/resources/下,你只需要将你需要下载的模板直接复制粘贴到resouces下就可以了。模板名字改成你自己的名字即可!!!
在这里插入图片描述

总结 : 如果你觉得文章不错,就给作者点个赞吧!有时间还会给大家分享更多项目中的功能文章!!!!

这篇关于Springboot+Vue 通用版Excel模板下载 简单超实用!几行代码实现项目中的Excel模板下载!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/204839

相关文章

Python按照24个实用大方向精选的上千种工具库汇总整理

《Python按照24个实用大方向精选的上千种工具库汇总整理》本文整理了Python生态中近千个库,涵盖数据处理、图像处理、网络开发、Web框架、人工智能、科学计算、GUI工具、测试框架、环境管理等多... 目录1、数据处理文本处理特殊文本处理html/XML 解析文件处理配置文件处理文档相关日志管理日期和

Python yield与yield from的简单使用方式

《Pythonyield与yieldfrom的简单使用方式》生成器通过yield定义,可在处理I/O时暂停执行并返回部分结果,待其他任务完成后继续,yieldfrom用于将一个生成器的值传递给另一... 目录python yield与yield from的使用代码结构总结Python yield与yield

python使用Akshare与Streamlit实现股票估值分析教程(图文代码)

《python使用Akshare与Streamlit实现股票估值分析教程(图文代码)》入职测试中的一道题,要求:从Akshare下载某一个股票近十年的财务报表包括,资产负债表,利润表,现金流量表,保存... 目录一、前言二、核心知识点梳理1、Akshare数据获取2、Pandas数据处理3、Matplotl

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

分布式锁在Spring Boot应用中的实现过程

《分布式锁在SpringBoot应用中的实现过程》文章介绍在SpringBoot中通过自定义Lock注解、LockAspect切面和RedisLockUtils工具类实现分布式锁,确保多实例并发操作... 目录Lock注解LockASPect切面RedisLockUtils工具类总结在现代微服务架构中,分布

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

精选20个好玩又实用的的Python实战项目(有图文代码)

《精选20个好玩又实用的的Python实战项目(有图文代码)》文章介绍了20个实用Python项目,涵盖游戏开发、工具应用、图像处理、机器学习等,使用Tkinter、PIL、OpenCV、Kivy等库... 目录① 猜字游戏② 闹钟③ 骰子模拟器④ 二维码⑤ 语言检测⑥ 加密和解密⑦ URL缩短⑧ 音乐播放

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入