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

 更新时间:2024年09月02日 11:56:20   作者:呛再首  
在开发过程中,我们经常需要将表格数据导出为 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,带样式的业务需求。

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

以上就是Vue导出el-table表格为Excel文件的两种方式的详细内容,更多关于Vue导出el-table为Excel的资料请关注脚本之家其它相关文章!

相关文章

  • Vue项目中安装依赖npm install一直报错的解决过程

    Vue项目中安装依赖npm install一直报错的解决过程

    这篇文章主要给大家介绍了关于Vue项目中安装依赖npm install一直报错的解决过程,要解决NPM安装依赖报错,首先要分析出错误的原因,文中将解决的过程介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • Vue element-ui父组件控制子组件的表单校验操作

    Vue element-ui父组件控制子组件的表单校验操作

    这篇文章主要介绍了Vue element-ui父组件控制子组件的表单校验操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-07-07
  • vue+springboot+element+vue-resource实现文件上传教程

    vue+springboot+element+vue-resource实现文件上传教程

    这篇文章主要介绍了vue+springboot+element+vue-resource实现文件上传教程,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-10-10
  • 你不可不知的Vue.js列表渲染详解

    你不可不知的Vue.js列表渲染详解

    这篇文章主要给大家介绍了关于你不可不知的Vue.js列表渲染的相关资料,文中通过示例代码介绍的非常详细,对大家学习或者使用Vue.js具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-10-10
  • vue组件中的样式属性scoped实例详解

    vue组件中的样式属性scoped实例详解

    vue组件中的style标签标有scoped属性时表明style里的css样式只适用于当前组件元素 。接下来通过本文给大家分享vue组件中的样式属性scoped实例详解,感兴趣的朋友跟随小编一起看看吧
    2018-10-10
  • vue项目引入本地bootstrap不生效问题及解决

    vue项目引入本地bootstrap不生效问题及解决

    这篇文章主要介绍了vue项目引入本地bootstrap不生效问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • vue.js中methods watch和computed的区别示例详解

    vue.js中methods watch和computed的区别示例详解

    methods,watch和computed都是以函数为基础的,但各自却都不同,这篇文章主要给大家介绍了关于vue.js中methods watch和computed区别的相关资料,需要的朋友可以参考下
    2021-08-08
  • vue axios sessionID每次请求都不同的原因以及修改方式

    vue axios sessionID每次请求都不同的原因以及修改方式

    这篇文章主要介绍了vue axios sessionID每次请求都不同的原因以及修改方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-12-12
  • Vue3中setup方法的用法详解

    Vue3中setup方法的用法详解

    在vue3版本中,引入了一个新的函数,叫做setup。这篇文章将为大家详细介绍一下Vue3中setup方法的用法,感兴趣小伙伴的可以了解一下
    2022-07-07
  • Vue中使用v-model双向数据绑定select、checked等多种表单元素的方法

    Vue中使用v-model双向数据绑定select、checked等多种表单元素的方法

     v-model 指令可以用在表单 input、textarea 及 select 元素上创建双向数据绑定,它会根据控件类型自动选取正确的方法来更新元素,本文给大家介绍Vue中如何使用v-model双向数据绑定select、checked等多种表单元素,感兴趣的朋友一起看看吧
    2023-10-10

最新评论