前言
在开发过程中,我们经常需要将表格数据导出为 excel 文件。大多数情况下,由后端处理即可,但是当数据量不大、需要快速响应用户操作、或者数据已经在前端进行处理和展示时,前端该如何实现呢。本文将介绍两种方法:一种是使用 xlsx.js
进行简单导出,另一种是使用 xlsx-style-medalsoft
进行样式化导出,包括多 sheet 支持。
方式一:简单导出
首先,我们使用 xlsx.js
库实现基本的表格导出功能。这种方法不包含样式,适用于快速导出数据。
import * as xlsx from 'xlsx'; // 创建一个新的工作簿 const book = xlsx.utils.book_new(); // 将 html 表格转换为工作表 const sheet = xlsx.utils.table_to_sheet(this.$refs.exporttableref.$el); // 将工作表添加到工作簿 xlsx.utils.book_append_sheet(book, sheet, "sheet1"); // 导出工作簿为 excel 文件 xlsx.writefile(book, "xxx统计.xlsx");
方式二:多 sheet 导出,带样式
对于更复杂的需求,如导出多个工作表或添加样式,我们可以使用 xlsx-style-medalsoft
库。
安装依赖
首先,安装必要的依赖:
这里注意版本号,有些版本可能会出现问题,我本地目前版本如下
"file-saver": "^2.0.5", "xlsx": "^0.16.9", "xlsx-style-medalsoft": "^0.8.13"
封装导出功能
接下来,我们封装一个函数,用于导出带样式的 excel 文件:
import filesaver from 'file-saver'; import * as xlsx from 'xlsx'; import xlsxstyle from 'xlsx-style-medalsoft'; const oms = {}; // 导出 excel 文件,支持多 sheet 和样式 oms.downloadxlsx = ({ sheets = [], name = '文件' }) => { const workbook = xlsx.utils.book_new(); sheets.foreach(sheetdata => { const { dom, sheetname, columnwidth = [], raw } = sheetdata; const table = dom; // 移除固定列,避免重复内容 ['el-table__fixed', 'el-table__fixed-right'].foreach(classname => { const fixedtable = table.queryselector(`.${classname}`); if (fixedtable) table.removechild(fixedtable); }); // 转换表格为工作表 const sheet = xlsx.utils.table_to_sheet(table, { raw }); // 删除空行 object.keys(sheet).foreach(key => { if (!key.startswith('!') && sheet[key].v === '') delete sheet[key]; }); // 设置列宽度 if (columnwidth.length > 0) { columnwidth.foreach((width, index) => { sheet['!cols'][index] = { wch: width }; }); } else { // 默认列宽 for (let i = 0; i < 30; i++) { sheet['!cols'][i] = { wch: 12.5 }; } } // 应用样式 object.keys(sheet).foreach(key => { if (!key.startswith('!')) { sheet[key].s = { font: { sz: 11, bold: false, name: '宋体', color: { rgb: '000000' } }, alignment: { horizontal: 'center', vertical: 'center', wraptext: false }, border: {} }; } }); // 合并单元格 const range = sheet['!merges']; if (range) { range.foreach(item => { const startcol = item.s.c, endcol = item.e.c; const startrow = item.s.r, endrow = item.e.r; const firstcell = sheet[xlsx.utils.encode_cell({ r: startrow, c: startcol })]; for (let row = startrow; row <= endrow; row++) { for (let col = startcol; col <= endcol; col++) { sheet[xlsx.utils.encode_cell({ r: row, c: col })] = firstcell; } } }); } // 添加工作表到工作簿 xlsx.utils.book_append_sheet(workbook, sheet, sheetname); }); // 导出工作簿 const exceldata = xlsxstyle.write(workbook, { booktype: 'xlsx', type: 'buffer' }); filesaver.saveas(new blob([exceldata], { type: 'application/octet-stream' }), `${name}.xlsx`); }; export default oms;
使用方法
最后,我们在需要使用的地方引入:
import oms from "@/utils/exporttoexcel"; oms.downloadxlsx({ sheets: [ { dom: this.$refs.rowtableref.$el, sheetname: this.rowdata[0].hospname, columnwidth: [20, 15, 15, 15, 15, 15, 15, 15] // 可选,设置列宽度 }, { dom: this.$refs.table.$el, sheetname: "明细", raw: true, columnwidth: [10, 15, 12, 15, 15, 15, 15, 15] // 可选,设置列宽度 } // 可添加更多工作表 ], name: "报告" });
通过这种方式,我们就实现了前端导出带样式的 excel 文件,满足多 sheet,带样式的业务需求。
但是需要注意的是如果数据量不大、需要快速响应用户操作、或者数据已经在前端进行处理和展示,前端来做导出是可以的。而如果数据量很大、需要复杂的数据处理、或者需要保证数据的安全性和一致性,后端导出可能更合适。
以上就是vue导出el-table表格为excel文件的两种方式的详细内容,更多关于vue导出el-table为excel的资料请关注代码网其它相关文章!
发表评论