
前言
在开发过程中,我们经常需要将表格数据导出为 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,带样式的业务需求。
但是需要注意的是如果数据量不大、需要快速响应用户操作、或者数据已经在前端进行处理和展示,前端来做导出是可以的。而如果数据量很大、需要复杂的数据处理、或者需要保证数据的安全性和一致性,后端导出可能更合适。
扫描二维码与小二CMS创始人沟通:
小二CMS专注于高端网站定制、系统开发、商城开发、外贸网站建设、公众号开发、小程序开发、网站优化推广、安全运维等技术领域。是高端定制网站领域著名服务商!
上一篇: 修改DNS解决个别网站无法访问的问题
下一篇: Vue中实现深度监听的方法小结
本文提供打造高效互动社区论坛网站的全方位指南与实用技巧,涵盖定位规划、功能设计、用户运营、内容管理与技术优化,并结合小二CMS的强大功能,帮助团队快速构建高粘性、高活跃的论坛平台。
本文系统讲解医院网站优化排名的具体流程,涵盖关键词研究、站内优化、内容建设、技术SEO及数据监测,并结合小二CMS的强大功能,助力医疗机构提升搜索引擎可见度与患者访问转化率。
本文深入解析模板网站建设与定制网站设计的核心区别,结合小二CMS的功能优势,帮助企业明确建站需求与投入方向,找到兼顾效率、成本与个性化的最佳方案,提升品牌竞争力。
本文聚焦合肥企业在数字时代的建站需求,解析如何借助小二CMS快速打造高性能官网,融合本地化营销与SEO策略,提升品牌形象与商业转化,开启全新增长篇章。
本文详解网页设计中的字体规范指南,结合“小二CMS”实践案例,解析如何通过科学排版、合理字阶与色彩搭配提升可读性与视觉美感,助力打造卓越用户体验。
针对物流与快递行业对高效获客、透明服务及数字化管理的需求,本文提出基于小二CMS的专业网站建设解决方案。通过在线下单、实时运单跟踪、智能客服等核心功能模块,结合小二CMS的可视化内容管理、多端适配与数据整合能力,助力物流快递企业构建集品牌展示、业务办理与客户运营于一体的数字化门户,实现服务效率提升与客户体验优化。
集团企业门户网站是展示企业综合实力、实现多层级协同与品牌统一的核心数字阵地。本文针对集团企业跨地域、多业务线、多层级的管理特点,提出基于小二CMS的定制化解决方案。通过多站点统一管理、分级权限管控、品牌内容聚合分发等核心能力,小二CMS助力集团企业构建“总部中枢+分支协同”的数字化门户体系,实现品牌形象一致、信息高效流转与内外资源整合,为集团战略落地与业务增长提供强力支撑。
针对初创型中小企业资源有限、数字化能力薄弱等痛点,本文提出基于小二CMS的一站式解决方案。从低成本内容管理到精准营销获客,从私域流量沉淀到高效运营协作,小二CMS凭借可视化操作、智能工具集成与灵活部署能力,助力初创企业以最小成本构建数字化竞争力,实现“从0到1”的快速成长。