Vue中实现导出表格的功能

在Vue中实现导出表格的功能,需要使用第三方库,比如xlsx和FileSaver.js。

  1. 首先安装依赖:

    npm install xlsx file-saver --save

  2. 创建导出表格的方法:

javascript 复制代码
import XLSX from 'xlsx';
import { saveAs } from 'file-saver';

export function exportTableToExcel(tableId, fileName) {
  const table = document.getElementById(tableId);
  const wb = XLSX.utils.table_to_book(table, { sheet: fileName });
  const wbout = XLSX.write(wb, { bookType: 'xlsx', bookSST: true, type: 'binary' });

  function s2ab(s) {
    const buf = new ArrayBuffer(s.length);
    const view = new Uint8Array(buf);
    for (let i = 0; i < s.length; i += 1) {
      view[i] = s.charCodeAt(i) & 0xFF;
    }
    return buf;
  }

  saveAs(new Blob([s2ab(wbout)], { type: 'application/octet-stream' }), `${fileName}.xlsx`);
}
  1. 调用导出方法:
javascript 复制代码
exportTableToExcel('tableId', 'example');

其中,tableId是要导出的表格的ID,example是导出的文件名。

  1. 增加样式

如果需要在导出的Excel表格中增加样式,可以使用xlsx-style库,安装方法如下:

复制代码
npm install xlsx-style --save

然后修改导出表格的方法:

javascript 复制代码
import XLSX from 'xlsx-style';
import { saveAs } from 'file-saver';

export function exportTableToExcel(tableId, fileName) {
  // 表格样式
  const wscols = [{ wpx: 100 }, { wpx: 200 }, { wpx: 300 }, { wpx: 400 }];

  const table = document.getElementById(tableId);
  const wb = XLSX.utils.book_new();
  const ws = XLSX.utils.table_to_sheet(table);
  ws['!cols'] = wscols;
  wb.SheetNames.push(fileName);
  wb.Sheets[fileName] = ws;
  const wbout = XLSX.write(wb, {
    bookType: 'xlsx',
    bookSST: true,
    type: 'binary',
    cellStyles: true,
  });

  function s2ab(s) {
    const buf = new ArrayBuffer(s.length);
    const view = new Uint8Array(buf);
    for (let i = 0; i < s.length; i += 1) {
      view[i] = s.charCodeAt(i) & 0xFF;
    }
    return buf;
  }

  saveAs(new Blob([s2ab(wbout)], { type: 'application/octet-stream' }), `${fileName}.xlsx`);
}

在这个实现中,我们通过const wscols定义了每一列的宽度,通过ws['!cols'] = wscols为每个sheet设置了列宽。

如果需要给单元格添加样式,可以参考官方文档中的Styles一章节。 https://github.com/SheetJS/sheetjs/blob/main/docs/styles.md

相关推荐
森叶19 分钟前
Electron 主进程中使用Worker来创建不同间隔的定时器实现过程
前端·javascript·electron
霸王蟹28 分钟前
React 19 中的useRef得到了进一步加强。
前端·javascript·笔记·学习·react.js·ts
霸王蟹28 分钟前
React 19版本refs也支持清理函数了。
前端·javascript·笔记·react.js·前端框架·ts
繁依Fanyi33 分钟前
ColorAid —— 一个面向设计师的色盲模拟工具开发记
开发语言·前端·vue.js·编辑器·codebuddy首席试玩官
codelxy36 分钟前
vue引用cesium,解决“Not allowed to load local resource”报错
javascript·vue.js
程序猿阿伟2 小时前
《社交应用动态表情:RN与Flutter实战解码》
javascript·flutter·react native
明似水2 小时前
Flutter 开发入门:从一个简单的计数器应用开始
前端·javascript·flutter
沐土Arvin2 小时前
前端图片上传组件实战:从动态销毁Input到全屏预览的全功能实现
开发语言·前端·javascript
Zww08912 小时前
el-dialog鼠标在遮罩层松开会意外关闭,教程图文并茂
javascript·vue.js·计算机外设
爱编程的鱼2 小时前
C#接口(Interface)全方位讲解:定义、特性、应用与实践
java·前端·c#