当前位置: 首页 > news >正文

怎么在网站里添加cnzz统计wordpress 加广告位

怎么在网站里添加cnzz统计,wordpress 加广告位,内网小网站的建设,临清网站建设价格在 Spring Boot 中结合 EasyExcel 实现动态表头导出&#xff08;无实体类&#xff0c;表头和字段&#xff08;前端传表名&#xff0c;字段值动态查询&#xff0c;返回List<Map<String,Object>>&#xff09;由前端传递&#xff09;可以通过以下步骤实现。以下是完整…

在 Spring Boot 中结合 EasyExcel 实现动态表头导出(无实体类,表头和字段(前端传表名,字段值动态查询,返回List<Map<String,Object>>)由前端传递)可以通过以下步骤实现。以下是完整示例:


1. 前端请求数据结构

假设前端传递的 JSON 格式如下:

{"headers": [{"title": "姓名", "field": "name"},{"title": "年龄", "field": "age"},{"title": "城市", "field": "city"}],"data": [{"name": "张三", "age": 25, "city": "北京"},{"name": "李四", "age": 30, "city": "上海"}]
}

2. 后端 DTO 定义

定义接收参数的 DTO 类:

@Data
public class ExportRequest {private List<Header> headers;private List<Map<String, Object>> data;@Datapublic static class Header {private String title;  // 表头名称private String field;  // 数据字段名}
}

3. Controller 层接口

处理导出请求:

@RestController
public class ExportController {@Autowiredprivate ExportService exportService;@PostMapping("/export")public void exportExcel(@RequestBody ExportRequest request, HttpServletResponse response) {exportService.export(request, response);}
}

4. Service 层实现

核心导出逻辑:

@Service
public class ExportService {public void export(ExportRequest request, HttpServletResponse response) {try {// 设置响应头response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("UTF-8");String fileName = URLEncoder.encode("动态导出.xlsx", "UTF-8");response.setHeader("Content-Disposition", "attachment; filename=" + fileName);// 获取输出流OutputStream outputStream = response.getOutputStream();// 动态构建表头和数据WriteSheet writeSheet = EasyExcel.writerSheet("Sheet1").build();ExcelWriter excelWriter = EasyExcel.write(outputStream).build();// 动态添加表头WriteTable writeTable = new WriteTable();List<List<String>> head = buildHead(request.getHeaders());writeTable.setHead(head);// 动态填充数据List<List<Object>> data = buildData(request.getHeaders(), request.getData());excelWriter.write(data, writeSheet, writeTable);// 关闭流excelWriter.finish();outputStream.flush();} catch (IOException e) {throw new RuntimeException("导出失败", e);}}// 构建表头private List<List<String>> buildHead(List<ExportRequest.Header> headers) {List<List<String>> head = new ArrayList<>();for (ExportRequest.Header header : headers) {List<String> columnHead = Collections.singletonList(header.getTitle());head.add(columnHead);}return head;}// 构建数据行private List<List<Object>> buildData(List<ExportRequest.Header> headers, List<Map<String, Object>> dataList) {List<List<Object>> data = new ArrayList<>();for (Map<String, Object> rowData : dataList) {List<Object> row = new ArrayList<>();for (ExportRequest.Header header : headers) {row.add(rowData.get(header.getField()));}data.add(row);}return data;}
}

5. 关键点说明

  1. 动态表头

    • 通过 buildHead() 方法将前端传递的 headers 转换为 EasyExcel 需要的 List<List<String>> 格式。
  2. 动态数据

    • 通过 buildData() 方法,根据 headers 中定义的 field 字段顺序,从 data 中提取对应值,构建数据行。
  3. 流式导出

    • 使用 ExcelWriter 直接操作输出流,避免内存溢出(适合大数据量)。

6. 测试与验证

使用 Postman 发送请求:

  • URL: POST http://localhost:8080/export

  • Body(JSON):

    {"headers": [{"title": "姓名", "field": "name"},{"title": "年龄", "field": "age"},{"title": "城市", "field": "city"}],"data": [{"name": "张三", "age": 25, "city": "北京"},{"name": "李四", "age": 30, "city": "上海"}]
    }
    
  • 响应:浏览器自动下载 动态导出.xlsx,内容如下:

    姓名年龄城市
    张三25北京
    李四30上海

7. 扩展优化

  • 字段校验:确保前端传递的 fielddata 中存在对应值。
  • 大数据量分页:如果数据量过大,可分页查询后分批写入。
  • 自定义样式:通过 WriteHandler 动态设置单元格样式(如字体、颜色)。

通过这种方式,无需定义实体类即可实现完全动态的 Excel 导出功能,表头和字段完全由前端控制。

http://www.laogonggong.com/news/62438.html

相关文章:

  • 成都 网站 建设南山网站建设深圳信科
  • 网站报价单模板wordpress 主题在哪看
  • 做站长建不好网站网站备案查询背景布
  • 保定网站制作软件阿里巴巴官网登录
  • 怎样申请做p2p融资网站官网排名优化
  • 网站搭建详细流程昆明手机网站开发
  • 网站开发教程 视频教程网站推广方案范例
  • win2003网站建设建设工程合同在性质上属于
  • 网站建设在学校中的作用国内 wordpress
  • 可视化的网站开发工具成都制作网站提供商
  • 购物网站开发分工家电维修品牌网站建设
  • 苏州免费自助建站网站建设集成装修全屋定制
  • 医疗网站跳出率平均是多少南昌网站seo技术
  • 学院网站建设流程百度快照提交入口
  • 服务器如何配置php网站公众号 一键导入wordpress
  • 大连网站网站搭建制作网站建设 义乌
  • 网站编辑器无法显示wordpress怎么只显示标题和摘要
  • 济宁三合一网站建设好多职业培训网站是怎么做的
  • 网站界面设计要素网站设计的专业流程
  • 响应式网站的概念网站 逻辑结构
  • dw制作网站教程ppt模板素材下载
  • 网站在服务器17一起做网站后台
  • 珠海单位网站建设贵州安顺住房城乡建设网站
  • 邳州网站制作php网站开发 远程
  • 做导航网站有发展吗.net网站开发实例
  • 聊城做网站推广地方企业电子网站的建设案例
  • 做淘客网站的公司优秀甜品网站
  • 做钢化膜网站网上申请店铺开网店的流程
  • 站长之家 网站模板网站建设公司上海做网站公司排名
  • 怎么做网站在里面填字西安建厂