vue3实现excel导出

前言:在开发一些管理系统的时候,常常会遇到表格导入导出的问题,总的来说呢,代码模板也挺固定的,仅以此博客作为记录以供参考

html部分

html 复制代码
<Button @click="downLoadPlan" type="primary">导出方案</Button>

ts部分

typescript 复制代码
<script lang="ts" setup>
import * as XLSX from 'xlsx';

const downLoadPlan = () => {
  // 这里data是我们要导出的数据
  // 因为这里导出的有三列,所以data的格式是一个包含多个[数据1,数据2,数据3]的数组
  // 在 data数组的开头插入表头['列1', '列2', '列3']
  data.unshift(['列1', '列2', '列3']);
  
  // 创建一个新的工作簿对象
  const wb = XLSX.utils.book_new();
  
  // 将 data 数组转换为工作表对象
  const ws = XLSX.utils.aoa_to_sheet(data);
  
  // 将工作表添加到工作簿中,命名为 'Sheet1'
  XLSX.utils.book_append_sheet(wb, ws, 'Sheet1');
  
  // 将工作簿转换为 Excel 格式的字节数组
  const excelBuffer = XLSX.write(wb, { bookType: 'xlsx', type: 'array' });
  
  // 创建一个 Blob 对象,类型为 Excel 文件
  const blob = new Blob([excelBuffer], {
    type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
  });
  
  // 为 Blob 对象创建一个 URL
  const url = URL.createObjectURL(blob);
  
  // 创建一个 a 元素,并设置下载链接和文件名
  const link = document.createElement('a');
  link.href = url;
  link.download = 导出文件.xlsx';
  
  // 模拟点击链接,触发文件下载
  link.click();
  
  // 释放 URL 对象
  URL.revokeObjectURL(url);
};
</script>
相关推荐
独隅13 小时前
前端工程化在Chrome插件开发中的具体实践完全指南
前端·chrome
sbjdhjd13 小时前
Tomcat(下) 集群高可用实战:反向代理・负载均衡・分布式 Session
运维·前端·云原生·开源·tomcat·负载均衡·memcached
IT WorryFree13 小时前
FortiGate常用资产 OID 清单,配套 Excel 台账模板字段
网络·人工智能·excel
MyFreeIT13 小时前
Excel Enable Content
excel
低保和光头哪个先来13 小时前
聊聊 CSS 编译和 scoped 实现
前端·css·vue.js
E_ICEBLUE13 小时前
将 Excel 表格插入 Word 文档的三种实用方案(Python 自动化)
python·word·excel
object not found13 小时前
Node.js fs 常用 API 整理:node:fs/promises、node:fs、fs 到底怎么用
开发语言·前端·javascript
俊哥工具13 小时前
027免费开源硬盘检测工具,一键查看健康度,杜绝数据丢失
pdf·电脑·word·excel·音视频
雷工笔记13 小时前
MES系列48-MES 系统「质量管理」完整设计与实施方案
开发语言·javascript·ecmascript
LiuJun2Son13 小时前
Angular 快速入门:服务和依赖注入
前端·javascript·angular.js