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

相关推荐
S***H2837 分钟前
Vue语音识别案例
前端·vue.js·语音识别
涔溪27 分钟前
通过Nginx反向代理配置连接多个后端服务器
vue.js·nginx
啦啦91188644 分钟前
【版本更新】Edge 浏览器 v142.0.3595.94 绿色增强版+官方安装包
前端·edge
蚂蚁集团数据体验技术1 小时前
一个可以补充 Mermaid 的可视化组件库 Infographic
前端·javascript·llm
LQW_home1 小时前
前端展示 接受springboot Flux数据demo
前端·css·css3
q***d1731 小时前
前端增强现实案例
前端·ar
IT_陈寒1 小时前
Vite 3.0 重磅升级:5个你必须掌握的优化技巧和实战应用
前端·人工智能·后端
JarvanMo1 小时前
Flutter 3.38 + Firebase:2025 年开发者必看的新变化
前端
Lethehong2 小时前
简历优化大师:基于React与AI技术的智能简历优化系统开发实践
前端·人工智能·react.js·kimi k2·蓝耘元生代·蓝耘maas
华仔啊2 小时前
还在用 WebSocket 做实时通信?SSE 可能更简单
前端·javascript