翼度科技»论坛 编程开发 JavaScript 查看内容

Vue导出el-table表格为Excel文件的两种方式

4

主题

4

帖子

12

积分

新手上路

Rank: 1

积分
12
前言

在开发过程中,我们经常需要将表格数据导出为 Excel 文件。大多数情况下,由后端处理即可,但是当数据量不大、需要快速响应用户操作、或者数据已经在前端进行处理和展示时,前端该如何实现呢。本文将介绍两种方法:一种是使用
  1. xlsx.js
复制代码
进行简单导出,另一种是使用
  1. xlsx-style-medalsoft
复制代码
进行样式化导出,包括多 sheet 支持。

方式一:简单导出

首先,我们使用
  1. xlsx.js
复制代码
库实现基本的表格导出功能。这种方法不包含样式,适用于快速导出数据。
  1. import * as XLSX from 'xlsx';

  2. // 创建一个新的工作簿
  3. const book = XLSX.utils.book_new();

  4. // 将 HTML 表格转换为工作表
  5. const sheet = XLSX.utils.table_to_sheet(this.$refs.exportTableRef.$el);

  6. // 将工作表添加到工作簿
  7. XLSX.utils.book_append_sheet(book, sheet, "Sheet1");

  8. // 导出工作簿为 Excel 文件
  9. XLSX.writeFile(book, "xxx统计.xlsx");
复制代码
方式二:多 sheet 导出,带样式

对于更复杂的需求,如导出多个工作表或添加样式,我们可以使用
  1. xlsx-style-medalsoft
复制代码
库。

安装依赖

首先,安装必要的依赖:
这里注意版本号,有些版本可能会出现问题,我本地目前版本如下
  1. "file-saver": "^2.0.5",
  2. "xlsx": "^0.16.9",
  3. "xlsx-style-medalsoft": "^0.8.13"
复制代码
封装导出功能

接下来,我们封装一个函数,用于导出带样式的 Excel 文件:
  1. import FileSaver from 'file-saver';
  2. import * as XLSX from 'xlsx';
  3. import XLSXStyle from 'xlsx-style-medalsoft';

  4. const OMS = {};

  5. // 导出 Excel 文件,支持多 sheet 和样式
  6. OMS.downLoadXlsx = ({ sheets = [], name = '文件' }) => {
  7.   const workbook = XLSX.utils.book_new();

  8.   sheets.forEach(sheetData => {
  9.     const { dom, sheetName, columnWidth = [], raw } = sheetData;
  10.     const table = dom;

  11.     // 移除固定列,避免重复内容
  12.     ['el-table__fixed', 'el-table__fixed-right'].forEach(className => {
  13.       const fixedTable = table.querySelector(`.${className}`);
  14.       if (fixedTable) table.removeChild(fixedTable);
  15.     });

  16.     // 转换表格为工作表
  17.     const sheet = XLSX.utils.table_to_sheet(table, { raw });

  18.     // 删除空行
  19.     Object.keys(sheet).forEach(key => {
  20.       if (!key.startsWith('!') && sheet[key].v === '') delete sheet[key];
  21.     });

  22.     // 设置列宽度
  23.     if (columnWidth.length > 0) {
  24.       columnWidth.forEach((width, index) => {
  25.         sheet['!cols'][index] = { wch: width };
  26.       });
  27.     } else {
  28.       // 默认列宽
  29.       for (let i = 0; i < 30; i++) {
  30.         sheet['!cols'][i] = { wch: 12.5 };
  31.       }
  32.     }

  33.     // 应用样式
  34.     Object.keys(sheet).forEach(key => {
  35.       if (!key.startsWith('!')) {
  36.         sheet[key].s = {
  37.           font: { sz: 11, bold: false, name: '宋体', color: { rgb: '000000' } },
  38.           alignment: { horizontal: 'center', vertical: 'center', wrapText: false },
  39.           border: {}
  40.         };
  41.       }
  42.     });

  43.     // 合并单元格
  44.     const range = sheet['!merges'];
  45.     if (range) {
  46.       range.forEach(item => {
  47.         const startCol = item.s.c, endCol = item.e.c;
  48.         const startRow = item.s.r, endRow = item.e.r;
  49.         const firstCell = sheet[XLSX.utils.encode_cell({ r: startRow, c: startCol })];
  50.         for (let row = startRow; row <= endRow; row++) {
  51.           for (let col = startCol; col <= endCol; col++) {
  52.             sheet[XLSX.utils.encode_cell({ r: row, c: col })] = firstCell;
  53.           }
  54.         }
  55.       });
  56.     }

  57.     // 添加工作表到工作簿
  58.     XLSX.utils.book_append_sheet(workbook, sheet, sheetName);
  59.   });

  60.   // 导出工作簿
  61.   const excelData = XLSXStyle.write(workbook, { bookType: 'xlsx', type: 'buffer' });
  62.   FileSaver.saveAs(new Blob([excelData], { type: 'application/octet-stream' }), `${name}.xlsx`);
  63. };

  64. export default OMS;
复制代码
使用方法

最后,我们在需要使用的地方引入:
  1. import OMS from "@/utils/exportToExcel";

  2. OMS.downLoadXlsx({
  3.   sheets: [
  4.     {
  5.       dom: this.$refs.rowTableRef.$el,
  6.       sheetName: this.rowData[0].hospName,
  7.       columnWidth: [20, 15, 15, 15, 15, 15, 15, 15] // 可选,设置列宽度
  8.     },
  9.     {
  10.       dom: this.$refs.table.$el,
  11.       sheetName: "明细",
  12.       raw: true,
  13.       columnWidth: [10, 15, 12, 15, 15, 15, 15, 15] // 可选,设置列宽度
  14.     }
  15.     // 可添加更多工作表
  16.   ],
  17.   name: "报告"
  18. });
复制代码
通过这种方式,我们就实现了前端导出带样式的 Excel 文件,满足多 sheet,带样式的业务需求。
但是需要注意的是如果数据量不大、需要快速响应用户操作、或者数据已经在前端进行处理和展示,前端来做导出是可以的。而如果数据量很大、需要复杂的数据处理、或者需要保证数据的安全性和一致性,后端导出可能更合适。
以上就是Vue导出el-table表格为Excel文件的两种方式的详细内容,更多关于Vue导出el-table为Excel的资料请关注脚本之家其它相关文章!

来源:https://www.jb51.net/javascript/32682813a.htm
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

举报 回复 使用道具