纯前端 Excel 表格导出

使用的库 exceljs

库: GitHub - exceljs/exceljs: Excel Workbook Manager

参考资料:https://juejin.cn/post/7152817023343394823

使用方式

导入

import * as Excel from 'exceljs';

创建工作簿和工作表

const workbook = new Excel.Workbook()
workbook.created = new Date()
workbook.modified = new Date()
const worksheet = workbook.addWorksheet('sheet1')

添加表头

const headers = Object.keys(dataArray[0]);
worksheet.addRow(headers);

在工作表中写入列表数据

dataArray.forEach(data => {
  const rowValues = headers.map(header => data[header]);
  worksheet.addRow(rowValues);
});

在工作表中插入图片

base64

const imageId = workbook.addImage({
  base64: imageBase64,
  extension: 'png',
});
worksheet.addImage(imageId, {
  // 指定在哪个单元格插入
  tl: { col: 2, row: dataArray.length+2 },
  // 指定图像大小
  ext: { width: 900, height: 500 }
});

基础表格 + 图片

// 导出 exel 表 包含图片
export function exportExcelWithImageAfterTable(name, dataArray, imageBase64=null) {
  // 创建工作簿和工作表
  const workbook = new Excel.Workbook()
  workbook.created = new Date()
  workbook.modified = new Date()
  const worksheet = workbook.addWorksheet('sheet1')

  // 添加表头
  const headers = Object.keys(dataArray[0]);
  worksheet.addRow(headers);

  // 在工作表中写入列表数据
  dataArray.forEach(data => {
    const rowValues = headers.map(header => data[header]);
    worksheet.addRow(rowValues);
  });
  // 在工作表中插入图片
  if (imageBase64) {
    const imageId = workbook.addImage({
      base64: imageBase64,
      extension: 'png',
    });
    worksheet.addImage(imageId, {
      // 指定在哪个单元格插入
      tl: { col: 2, row: dataArray.length+2 },
      // 指定图像大小
      ext: { width: 900, height: 500 }
    });
  }
  workbook.xlsx.writeBuffer().then(function (buffer) {
    const blob = new Blob([buffer], { type: 'application/octet-stream' });
    // 下载 Excel 文件
    const filename = `${name}.xlsx`;
    if (typeof window.navigator.msSaveBlob !== 'undefined') {
      // 兼容IE浏览器
      window.navigator.msSaveBlob(blob, filename);
    } else {
      // 其他浏览器
      const url = window.URL.createObjectURL(blob);
      const link = document.createElement('a');
      link.href = url;
      link.setAttribute('download', filename);
      document.body.appendChild(link);
      link.click();
      document.body.removeChild(link);
    }
  }).catch(e => {
    console.log('err', e)
  })
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值