Vue 3 中导出 Excel 文件

在 Vue 3 中导出 Excel 文件,通常可以使用一些流行的 JavaScript 库,如 SheetJS (xlsx) 或者 exceljs。这里我将分别介绍如何使用这两个库来在 Vue 3 应用中导出 Excel 文件。

方法 1:使用 SheetJS (xlsx)

  1. 安装 SheetJS

    首先,你需要安装 xlsx 库。在你的 Vue 项目中运行以下命令:

    npm install xlsx

2.在 Vue 组件中使用 xlsx

然后,你可以在 Vue 组件中导入并使用 xlsx 来创建和导出 Excel 文件。

复制代码
<template>
  <button @click="exportToExcel">导出 Excel</button>
</template>
 
<script setup>
import * as XLSX from 'xlsx';
 
const exportToExcel = () => {
  // 创建工作表数据
  const data = [
    ["姓名", "年龄", "职业"],
    ["张三", 28, "工程师"],
    ["李四", 35, "设计师"],
    ["王五", 29, "教师"]
  ];
 
  // 创建工作表
  const ws = XLSX.utils.aoa_to_sheet(data);
 
  // 创建工作簿并添加工作表
  const wb = XLSX.utils.book_new();
  XLSX.utils.book_append_sheet(wb, ws, "Sheet1");
 
  // 导出 Excel 文件
  XLSX.writeFile(wb, "example.xlsx");
};
</script>

方法 2:使用 exceljs

  1. 安装 exceljs

    在你的 Vue 项目中安装 exceljs

    npm install exceljs

复制代码
  2.在 Vue 组件中使用 exceljs
复制代码
<template>
  <button @click="exportToExcel">导出 Excel</button>
</template>
 
<script setup>
import ExcelJS from 'exceljs';
 
const exportToExcel = async () => {
  // 创建工作簿和工作表
  const workbook = new ExcelJS.Workbook();
  const worksheet = workbook.addWorksheet('My Sheet');
  
  // 添加数据到工作表
  worksheet.addRow(['姓名', '年龄', '职业']);
  worksheet.addRow(['张三', 28, '工程师']);
  worksheet.addRow(['李四', 35, '设计师']);
  worksheet.addRow(['王五', 29, '教师']);
  
  // 设置列宽等(可选)
  worksheet.columns.forEach(column => { column.width = 20; });
  
  // 导出 Excel 文件到浏览器或保存到服务器(示例:浏览器下载)
  workbook.xlsx.writeBuffer().then((buffer) => {
    const blob = new Blob([buffer], { type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet' });
    const url = URL.createObjectURL(blob);
    const a = document.createElement('a');
    a.href = url;
    a.download = 'example.xlsx';
    a.click();
    URL.revokeObjectURL(url); // 释放内存中的 URL 对象资源。
  });
};
</script>
复制代码
以上两种方法都可以在 Vue 3 中实现 Excel 文件的导出。你可以根据自己的需求选择合适的库。如果你需要处理更复杂的 Excel 文件(如包含图片、公式等),exceljs 可能提供更多灵活性和功能。而 xlsx 则因其简单易用而受到许多开发者的喜爱。
相关推荐
学嵌入式的小杨同学2 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
weixin_425543732 小时前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
Mr Xu_3 小时前
【Vue3 + ECharts 实战】正确使用 showLoading、resize 与 dispose 避免内存泄漏
前端·信息可视化·vue·echarts
0思必得03 小时前
[Web自动化] Selenium设置相关执行文件路径
前端·爬虫·python·selenium·自动化
雯0609~4 小时前
hiprint:实现项目部署与打印1-官网提供普通html版本
前端·html
不绝1914 小时前
UGUI——进阶篇
前端
~牧马~4 小时前
【记录63】electron打包vue项目之踩坑
vue.js·electron·electron与node兼容
Exquisite.4 小时前
企业高性能web服务器(4)
运维·服务器·前端·网络·mysql
2501_944525545 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐5 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法