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

2024-11-02 13:47:42
摘要:在开发过程中,我们经常需要将表格数据导出为 Excel 文件。大多数情况下,由后端处理即可,但是当数据量不大、需要快速响应用户操作、或者数据已经在前端进行处理和展示时,前端该如何实现呢。

前言
在开发过程中,我们经常需要将表格数据导出为 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,带样式的业务需求。

但是需要注意的是如果数据量不大、需要快速响应用户操作、或者数据已经在前端进行处理和展示,前端来做导出是可以的。而如果数据量很大、需要复杂的数据处理、或者需要保证数据的安全性和一致性,后端导出可能更合适。

你觉得这篇文章怎么样?

6 0
本文标签: Vue导出el-table

我们立足于合肥面向安徽乃至全国全球市场,我们拥有一支经验丰富、创意独到、团结协作的专业技术团队。我们立志把最好的技术通过最有效、最简单的方式提供给客户,为客户提供最佳的解决方案,我们将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,帮助客户在新经济时代下,把握商机和发展空间,并获得绝对的竞争力!我们专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!

扫描二维码与小二CMS创始人沟通

7*24小时为您服务

小二CMS专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!

本文标题:Vue导出el-table表格为Excel文件的两种方式
免责声明:文章《Vue导出el-table表格为Excel文件的两种方式》来至网络,文章表达观点不代表本站观点,文章版权属于原作者所有,若有侵权,请联系本站站长处理!
—— 小二CMS创始人微信 ——
关于我们

小二CMS专注于高端网站建设服务及定制,拥有丰富的企业网站建站经验。 近年来制作并完成了许多网站建设案例,企业品牌官网、营销型网站的建设、B2C网上商城系统开发、行业门户网站等平台开发,我们还提供了网站的策划、设计、开发、布署、安全等一站式专业的网站建设解决方案。小二CMS致力于研发国内最专业、功能最强大,扩展性能最自由灵活的高端行业通用的网站系统。我们做的不仅仅是网站系统,更多的是成就您的成功!

我们的优势

十年建站服务经验
服务1800家企业
资深行业分析策划
前沿视觉设计、研发能力
前端代码深度符合SEO优化
千家成功案例

独家源码出售
具有完备的项目管理
完善的售后服务体系
深厚的网络运营经验
时刻新技术领先研发能力
方便二次开发

我们的不同

我们是一个年轻且富有激情的团队,我们沉迷于代码并陶醉在设计之中。我们非设计,不生活;无兄弟,不编程!可年轻并不意味着没有经验。团队成员均来自各顶尖设计公司及软件公司,我们对网站设计及开发驾轻就熟,有着数百个成功案例。我们坚信用心服务,用实力说话!我们的使命:通过我们的努力,让技术改变命运!我们的宗旨:客户第一,品质至上!我们的信念:唯有客户的成功,才是我们的成功!

不忘初心,方得始终
中高端网站定制开发服务商
与我们取得联系

好作品自己会说话,

我们敬畏您给予的点滴信任 !

期待携手合作,请立即咨询我们:
QQ咨询 微信咨询
我们用心,期待您成为我们的客户

微信号:
添加微信好友, 详细咨询相关信息。

复制并跳转微信
19810950281