前后端分离导出excel
时间: 2023-11-08 22:04:48 浏览: 206
在前后端分离项目中,实现Excel导出功能可以通过以下步骤完成:
1. 在前端页面中添加导出按钮,并绑定导出方法。可以使用element-ui的`el-button`组件来创建按钮,并通过点击事件调用导出方法。
2. 在导出方法中,使用两种方式导出Excel:`blob`导出和`a标签`导出。
3. `blob`导出方式:在导出方法中,使用axios或者其他网络请求库发送请求,将数据以流的形式返回。接收到返回的流数据后,创建一个`Blob`对象,并设置`content-type`为`application/vnd.openxmlformats-officedocument.spreadsheetml.sheet`。然后通过`URL.createObjectURL()`将`Blob`对象转换成临时链接,最后创建一个`a`标签,设置`href`为临时链接,并设置`download`属性为导出的文件名,最后模拟点击`a`标签实现文件的下载。
4. `a标签`导出方式:在导出方法中,创建一个`a`标签,设置`href`为后端接口的URL地址,并设置`download`属性为导出的文件名,最后模拟点击`a`标签实现文件的下载。
需要注意的是,在后端实现Excel导出功能时,可以使用Apache POI库进行操作。可以通过在`pom.xml`文件中添加POI依赖来引入所需的库。
相关问题
SpringBoot前后端分离项目Excel导出数据的代码实现
下面是SpringBoot前后端分离项目Excel导出数据的代码实现步骤:
1. 引入poi包
在pom.xml中添加以下依赖:
```
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>4.1.2</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>4.1.2</version>
</dependency>
```
2. 编写Excel导出工具类
创建ExcelUtil.java文件,编写Excel导出工具类,具体代码如下:
```
public class ExcelUtil {
/**
* 导出excel
* @param response
* @param fileName 文件名
* @param headers 表头
* @param dataList 数据
*/
public static void exportExcel(HttpServletResponse response, String fileName, String[] headers, List<List<String>> dataList) {
// 创建工作簿
XSSFWorkbook workbook = new XSSFWorkbook();
// 创建表格
XSSFSheet sheet = workbook.createSheet();
// 设置列宽
for (int i = 0; i < headers.length; i++) {
sheet.setColumnWidth(i, 20 * 256);
}
// 创建表头行
XSSFRow row = sheet.createRow(0);
// 设置表头
for (int i = 0; i < headers.length; i++) {
XSSFCell cell = row.createCell(i);
cell.setCellValue(headers[i]);
}
// 添加数据
for (int i = 0; i < dataList.size(); i++) {
XSSFRow dataRow = sheet.createRow(i + 1);
List<String> rowData = dataList.get(i);
for (int j = 0; j < rowData.size(); j++) {
XSSFCell cell = dataRow.createCell(j);
cell.setCellValue(rowData.get(j));
}
}
// 设置响应头
response.setContentType("application/octet-stream");
try {
fileName = URLEncoder.encode(fileName, "UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
response.setHeader("Content-Disposition", "attachment;filename=" + fileName);
// 输出Excel文件
try {
workbook.write(response.getOutputStream());
} catch (IOException e) {
e.printStackTrace();
}
}
}
```
3. 调用Excel导出工具类
在Controller中调用Excel导出工具类,具体代码如下:
```
@Controller
public class ExcelController {
@RequestMapping("/export")
public void export(HttpServletResponse response) {
// 文件名
String fileName = "测试导出.xlsx";
// 表头
String[] headers = {"姓名", "年龄", "性别"};
// 数据
List<List<String>> dataList = new ArrayList<>();
dataList.add(Arrays.asList("张三", "23", "男"));
dataList.add(Arrays.asList("李四", "25", "女"));
dataList.add(Arrays.asList("王五", "28", "男"));
// 调用Excel导出工具类
ExcelUtil.exportExcel(response, fileName, headers, dataList);
}
}
```
4. 配置跨域访问
由于是前后端分离项目,需要配置跨域访问,具体代码如下:
```
@Configuration
public class CorsConfig {
private CorsConfiguration buildConfig() {
CorsConfiguration corsConfiguration = new CorsConfiguration();
corsConfiguration.addAllowedOrigin("*");
corsConfiguration.addAllowedHeader("*");
corsConfiguration.addAllowedMethod("*");
return corsConfiguration;
}
@Bean
public CorsFilter corsFilter() {
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
source.registerCorsConfiguration("/**", buildConfig());
return new CorsFilter(source);
}
}
```
以上就是SpringBoot前后端分离项目Excel导出数据的代码实现步骤。
VUE 前后端分离导出
前后端分离导出是指在Vue前端项目中使用axios发送请求到后端接口,然后后端通过处理请求,生成一个Excel文件,并将该文件作为响应返回给前端,最终前端可以通过点击按钮或其他方式将该Excel文件下载到本地。
在给出具体步骤之前,首先需要明确一些前提条件:
1. 前端使用Vue框架,并配置了axios库来发送网络请求。
2. 后端使用Java语言,并使用了EasyExcel库来生成Excel文件。
下面是具体步骤:
1. 在前端的request.js文件中,使用axios.create方法创建一个axios实例,并设置一些默认配置,如请求的基础URL和超时时间。
2. 在前端的exportOrder.js文件中,定义一个名为exportOrders的函数,该函数封装了发送导出订单请求的逻辑。其中,通过调用之前创建的axios实例的request方法发送GET请求,并传入一些配置参数,如URL、响应类型为blob以及请求参数。
3. 在前端的order.vue文件中,在导出订单的按钮上绑定一个点击事件,通过调用exportOrder函数来触发导出订单的逻辑。在该函数中,首先清空查询参数,然后调用exportOrders函数发送请求。在请求成功的回调函数中,创建一个a标签和一个Blob对象,并设置a标签的相关属性,如href和download,然后将a标签添加到文档中,并模拟点击a标签来触发下载操作,最后将a标签从文档中移除。
4. 在后端的Java代码中,使用@GetMapping注解指定导出订单的接口路径,通过@ApiOperation注解添加接口描述。在方法体中,设置响应的Content-Type为application/vnd.ms-excel,以及字符编码为utf-8。然后通过URLEncoder对文件名进行编码,并设置响应头的Content-Disposition属性,将文件名作为附件下载。最后,使用EasyExcelFactory.write方法将订单数据写入输出流中,生成Excel文件。
需要注意的是,前端和后端的代码需要相互配合,前端发送请求时需要与后端的接口路径和参数保持一致,而后端返回的Excel文件需要与前端的处理逻辑相匹配,确保能够成功下载和解析。
以上就是Vue前后端分离导出的相关步骤和注意事项。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [vue前后端分离导出excel](https://blog.csdn.net/tom_zhai/article/details/116229346)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
阅读全文