vue3中将表格导出excel的方法(极简且有效)

🥰博主:小猫娃来啦

🥰文章核心:vue2或vue3中将表格导出excel的通用方法

文章目录

安装依赖,导入模块

安装

javascript 复制代码
npm i xlsx
或者
pnpm i xlsx

导入

javascript 复制代码
import * as XLSX from 'xlsx' 

这边有个说法:

在JavaScript中,使用import语句导入模块时,有两种不同的导入方式:默认导入命名导入

import XLSX from 'xlsx' 是默认导入,它假设模块中有一个默认导出的对象。但是,在 xlsx 模块中,并没有默认导出的对象的时候,就会报错。

import * as XLSX from 'xlsx' 是命名导入,它将整个模块作为一个命名空间引入,并将模块中的所有导出都作为该命名空间对象的属性。这种方式适用于 xlsx 模块,因为它将 XLSX 作为对象导出。

因此,你需要使用 import * as XLSX from 'xlsx' 来正确导入并使用 xlsx 模块。这样可以将整个模块作为命名空间引入,以便访问其中的方法和属性。


需要注意的

<script setup> 区块中,我们使用 ref 创建一个响应式引用变量 exportTableReflist,并初始化它们的值。

然后,我们需要定义了一个点击函数,暂且设置名字为exportBtn,用于处理导出按钮的点击事件。在该函数中,我们从 exportTableRef 中获取 el-table 的 DOM 元素,并执行与之前相同的导出操作。

在模板中,我们仍然可以引用 exportTableReflist,并将 exportBtn 绑定到导出按钮的点击事件上。

请注意,在 <script setup> 区块中,我们使用的是 ES 模块语法,需要确保你的环境支持该语法。


完整导出代码

html 复制代码
<script setup>
import { ref } from 'vue';
import XLSX from 'xlsx';

const exportTableRef = ref(null);
const list = ref([
  // 表格数据
]);

const exportBtn = () => {
  const tableDom = exportTableRef.value?.$el;
  if (!tableDom) {
    return;
  }
  
  const wb = XLSX.utils.table_to_book(tableDom);
  XLSX.writeFile(wb, '表格数据.xlsx');
};
</script>

<template>
  <div>
    <el-table
      ref="exportTableRef"
      :data="list"
      :cell-style="{ textAlign: 'center' }"
      :header-cell-style="{ 'text-align': 'center' }"
    >
      <!-- 表格列定义 -->
    </el-table>
    <el-button style="margin-bottom: 10px" type="primary" @click="exportBtn">导出 Excel 表格</el-button>
  </div>
</template>

原理

  • 首先,代码获取了一个表格的 DOM 元素,即 tableDom,这是通过 exportTableRef.value?.$el 获取的。这个 DOM 元素必须是一个有效的 HTML 表格元素才能进行后续的导出操作。

  • 然后,使用 XLSX.utils.table_to_book() 方法将这个表格 DOM 元素转换为一个 workbook 对象 wbtable_to_book() 方法会将表格中的每个单元格的数据提取出来,并按照 Excel 的格式转换成一个 workbook 对象。

  • 最后,利用 XLSX.writeFile() 方法将 workbook 对象 wb 导出为一个名为 "表格数据.xlsx" 的 Excel 文件。这一步会将 workbook 对象转换为二进制的 Excel 文件,并触发文件下载到用户的设备上。

简而言之,就是用 xlsx 库中的 table_to_book() 方法,将 HTML 表格转换为 workbook 对象,并通过 XLSX.writeFile() 方法将 workbook 导出为 Excel 文件


效果


相关推荐
之歆3 分钟前
DAY_18深度解析:数据类型转换与运算符全攻略(上)
前端·javascript
大家的林语冰11 分钟前
pnpm 11 发布,弃用 JSON 和 npm CLI,进化为纯 ES6 模块,新增 pnpm pack-app 等命令,供应链保护默认启用,要求 Node
前端·javascript·node.js
Alice-YUE30 分钟前
深入解析 JS 事件循环:浏览器与 Node.js 的差异全解析
前端·javascript·笔记·学习
HYCS32 分钟前
用pixijs实现fabricjs(二):对象的基础位置信息
前端·javascript·canvas
Alice-YUE33 分钟前
【无标题】
开发语言·javascript·ecmascript
淸湫35 分钟前
项目中使用了全局权限管理,请详细描述如何通过Vue Router的路由守卫来实现全局权限控制?
前端·vue.js
Twsit丶38 分钟前
ECMAScript 常用特性整理(ES6 — ES13)
javascript
李剑一44 分钟前
前端必看 | Vue 刷新页面,生命周期钩子直接 "罢工",原来问题在这?90% 开发者都栽过!
前端·vue.js
閞杺哋笨小孩1 小时前
域名驱动多租户入驻:后台配置 + 前端解析
前端·vue.js
TA远方2 小时前
【JavaScript】Promise对象使用方式研究和理解
javascript·编程·脚本·web·js·promise·委托