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

news2024/12/27 12:52:32

在这里插入图片描述
🥰博主:小猫娃来啦
🥰文章核心:vue2或vue3中将表格导出excel的通用方法

文章目录

  • 安装依赖,导入模块
  • 需要注意的
  • 完整导出代码
  • 原理
  • 效果

安装依赖,导入模块

安装

npm i xlsx
或者
pnpm i xlsx

导入

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 模块语法,需要确保你的环境支持该语法。


完整导出代码

<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 文件


效果

在这里插入图片描述

在这里插入图片描述


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/891298.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

图片转换pdf怎么转换?这几种方法很好用

图片转换pdf怎么转换&#xff1f;将图片转换为pdf可以使你更方便地分享和存储文件。相比于图片格式&#xff0c;pdf格式更加通用&#xff0c;可以在不同的设备和操作系统上打开和查看。此外&#xff0c;pdf格式还可以更好地保护你的文件&#xff0c;可以设置密码保护和防止复制…

vue3 基础知识(webpack) 02

你好&#xff0c;今天过的怎么样呀&#xff0c;嘿嘿&#xff0c;加油夏 &#x1f495; 文章目录 一、组件二、如何支持SFC三、webpack 打包工具 一、组件 使用组件中我们可以获得非常多的特性&#xff1a; 代码的高亮&#xff1b;ES6、CommonJS的模块化能力&#xff1b;组件作…

WPF的CheckBox中的三个状态

WPF的CheckBox中的三个状态 CheckBox控件和RadioButton控件是继承自ToggleButton类&#xff0c;这意味着用户可切换他们的开关状态&#xff0c;其中IsChecked属性是可空的Boolean类型&#xff0c;这意味着该属性可以设置为true&#xff0c;false或null。 null值表示不确定状态…

分类预测 | MATLAB实现WOA-CNN-BiGRU-Attention数据分类预测

分类预测 | MATLAB实现WOA-CNN-BiGRU-Attention数据分类预测 目录 分类预测 | MATLAB实现WOA-CNN-BiGRU-Attention数据分类预测分类效果基本描述模型描述程序设计参考资料 分类效果 基本描述 1.Matlab实现WOA-CNN-BiGRU-Attention多特征分类预测&#xff0c;多特征输入模型&…

看完尤雨溪知乎343条回答,我学到了这些!

最近看完了尤雨溪的知乎 343 条回答和 25 篇文章&#xff0c;记录下一些内容&#xff08;每条仅摘录部分内容&#xff09;&#xff0c;分享给大家&#xff01; 怎么才能有尤雨溪一半强&#xff0c;该怎么学习&#xff1f; 我更愿意把 “强” 理解为 “制造 impact 的能力”&a…

如何在vue3中封装并使用echarts组件

一. 安装echarts npm install echarts --save 二. 按需加载创建一个echarts文件夹&#xff0c;并创建配置文件 //引入echarts import * as echarts from echarts/core//引入柱状图&#xff0c;折线图 import { BarChart, LineChart } from echarts/charts// 引入提示框&#x…

论文及代码详解——可变形卷积(DCNv1)

文章目录 论文详解Deformable ConvolutionDeformable RoI PoolingDeformable ConvNetsUnderstanding Deformable ConvNets 代码详解 论文&#xff1a;《Deformable Convolutional Networks》 论文详解 Deformable Convolution 普通卷积的数学表达 普通的二维卷积包括两个步骤:…

小知识积累

1、使用JSON.parse(JSON.stringify()) 深拷贝时会出现的问题 var obj {a: "zs",b: undefined,c: Symbol("score"),d: null,e: function () {console.log("show");},};console.log(JSON.parse(JSON.stringify(obj)));很明显undefined、函数、sym…

Netty+springboot开发即时通讯系统笔记(三)

实现长连接负载均衡策略 登录成功返回登陆的im地址。 1.在公共模块里写个RouteHandle接口&#xff0c;然后他的实现类去实现不同的均衡策略。 2.在业务模块的config文件下的beanConfig中定义一个Bean routeHandle&#xff0c;从配置文件中获取不同的负载均衡策略来初始化Rou…

苹果电脑会自动清理垃圾吗 苹果电脑系统垃圾怎么清除

苹果电脑是很多人喜欢使用的一种电脑&#xff0c;它有着优美的外观&#xff0c;流畅的操作系统&#xff0c;丰富的应用程序和高效的性能。但是&#xff0c;随着时间的推移&#xff0c;苹果电脑也会产生一些不必要的文件和数据&#xff0c;这些文件和数据就是我们常说的垃圾。那…

半导体退火那些事(2)

2.半导体退火的作用 2.1改善半导体的电学性能 退火过程中&#xff0c;材料中的缺陷得到修理&#xff0c;杂质原子和材料内的杙错得到排列&#xff0c;位于能带中动力学的载流子少&#xff0c;能级也就相对于更加密集。因而在退火之后&#xff0c;半导体材料中的电子、空穴浓度…

RabiitMq-4工作队列/消息应答

1.工作队列 工作机制类似一个生产者&#xff0c;多个消费者。工作队列采用轮训的机制&#xff0c;即工作线程一次只能处理一个消息&#xff0c;轮流处理 公共方法 public class MqUtiles {public static final String QUEUE_NAME"hello";public static Channel fu…

预防SQL漏洞注入和规避网络攻击

前言: 虽然近些年SQL注入已经被各类的安全开发框架规避了绝大部分&#xff0c;但SQL注入作为一种最原始的攻击手段之一&#xff0c;破坏力仍然十分强大&#xff0c;因为它直捣黄龙数据中心。所以未雨绸缪&#xff0c;各位不可不重视。 预防SQL注入方法措施&#xff1a; 服务器…

【微信小程序】阶段开发总结2

【微信小程序】阶段开发总结2 《工欲善其事&#xff0c;必先利其器》 一、选择器组件Picker 由于业务需求&#xff0c;需要比较个性化的时间Picker组件和基础Picker组件&#xff0c;便基于微信提供的 picker-view 自行封装了两个Picker组件。 基础Picker&#xff1a; 代码示…

低代码平台这5大选型要素值得参考

伴随低代码的流行&#xff0c;选购低代码成为越来越多人需要面临的挑战。选平台容易&#xff0c;换平台难。不同的企业场景不同&#xff0c;对低代码平台的需求也不一样。因此在做出技术选型时&#xff0c;有五个关键要素需要考虑。 要点1&#xff1a;是否符合自身需求 这是最核…

[JavaWeb]【四】web后端开发-SpringBootWeb入门

目录 一 Spring 二 SpringBootWeb入门 2.1 入门需求 2.2 分析 2.3 开始创建SpringBootWeb 2.4 创建类实现需求 2.5 启动程序 2.6 访问 三 HTTP协议 3.1 HTTP-概述 3.2 HTTP-请求协议 3.3 HTTP-响应协议 3.3.1 响应状态码 && 响应类型 3.4 HTTP-协议解析 前言…

【一】ubuntu20.04上搭建containerd版( 1.2.4 以上)k8s及kuboard V3

k8s 部署全程在超级用户下进行 sudo su本文请根据大纲顺序阅读&#xff01; 一、配置基础环境&#xff08;在全部节点执行&#xff09; 1、安装docker 使用apt安装containerd 新版k8s已经弃用docker转为containerd&#xff0c;如果要将docker改为containerd详见&#xff1a…

6、Mysql免安装版本的配置与使用(2023-08)

1、下载 官网&#xff1a;https://www.mysql.com/downloads/ 点击前往 1.1 官网首页 1.2 首页往下翻&#xff0c;到达下图点击 1.3 选择如图Mysql Cimmunity Server 1.4 选择版本 1.5 点击开始下载 2、安装 2.1 配置环境变量 打开电脑环境变量&#xff0c;在环境变量path中…

抖音矩阵系统源代码部署开发详解

一、引言 抖音矩阵系统是一款基于抖音平台的自动化短视频创作和发布工具。通过对源代码的部署和开发&#xff0c;可以实现大规模、高效率的短视频生产和发布&#xff0c;提高抖音账号的曝光量和关注度。本文将详细介绍抖音矩阵系统源代码的部署和开发过程&#xff0c;帮助读者…

centos安装pandoc

1、首先从官网下载安装包(Release pandoc 3.1.6 jgm/pandoc GitHub) 2、上传到服务器(这里放到 /root目录下了)&#xff0c;进行解压 tar -zxvf pandoc-3.1.6-linux-amd64.tar.gz&#xff0c;解压后的文件 3、然后使用命令 ln -s /root/pandoc-3.1.6/bin/pandoc /usr/bin/p…