当前位置: 首页 > article >正文

Vue3:将表格数据下载为excel文件

需求

将表格数据或者其他形式的数据下载为excel文件

技术栈

Vue3、ElementPlus、

实现

1、安装相关的库
  • 下载xlsx 和 file-saver 库
npm install -S file-saver
npm install -S xlsx
  • 引入XLSX库和FileSaver库
import XLSX from 'xlsx';
import FileSaver from 'file-saver';
2、添加导出按钮
  • 需要一个“导出”按钮,并给它绑定一个点击事件
    (1)点击该按钮可以将表格的数据下载为excel文件;
    (2)关于按钮的图标可以引用elementplus里的下载图标
  • 另外,可以添加触发提示,告知用户可以进行数据下载
    关于触发提示可以引用elementplus里面的el-tooltip组件
  • 大致效果如下:
    在这里插入图片描述
  • 导出按钮、触发提示、表格的包含关系如下:
    在这里插入图片描述
  • 相关代码:
<!-- 表格 -->
<div class="TopCourse">
  <div class="navTop">
	<!-- 触发提示 -->
	<el-tooltip
	  class="box-item"
	  effect="dark"
	  content="下载全部数据"
	  placement="top-start"
	>
	  <!-- 下载按钮 -->
	  <el-button type="primary" :icon="Download" @click="userExport" />
	</el-tooltip>
  </div>

  <!-- 表格 -->
  <el-table
	id="myTable"
	:data="tableData"
	style="width: 95%"
	:header-cell-style="{ 'text-align': 'center' }"
	:cell-style="{ 'text-align': 'center' }"
  >
	<el-table-column prop="index" label="No." />
	<el-table-column prop="ID" label="ID" />
	
  </el-table>
</div>
	
3、函数:将数据下载为excel文件
  • 使用 SheetJS 库将表格数据转换为 Excel 文件格式;
  • 使用 file-saver 库将生成的 Excel 文件保存到本地
// tableDataAllL:指excel数据的全部汇总(根据实际情况自己去补充)
var tableDataAll = [];
// 将数据下载为excel文件
function userExport() {
  const worksheet = XLSX.utils.json_to_sheet(tableDataAll);
  const workbook = XLSX.utils.book_new();
  XLSX.utils.book_append_sheet(workbook, worksheet, "Sheet1");
  const excelBuffer = XLSX.write(workbook, {
	bookType: "xlsx",
	type: "array",
  });
  const blob = new Blob([excelBuffer], {
	type: "application/vnd.ms-excel",
  });
  FileSaver.saveAs(blob, "tableDataAll"); // 下载文件 文件名
}
  • 以上函数可以直接引用,修改对应的部分即可
    在这里插入图片描述

http://www.kler.cn/a/107891.html

相关文章:

  • Kivy,跨平台UI的艺术家
  • Unity3D使用GaussianSplatting加载高斯泼溅模型
  • Sql 创建用户
  • 00000008_C并发编程与多线程
  • C#语言的网络编程
  • NRC优先级中比较特殊的—NRC0x13和NRC0x31
  • MODBUS-RTU从站通信(SMART PLC作为MODBUS-RTU从站)
  • MySQL - 什么是覆盖索引和索引下推?
  • 一文彻底理解python浅拷贝和深拷贝
  • vue手动拖入和导入excel模版
  • 【MyBatis Plus】初识 MyBatis Plus,在 Spring Boot 项目中集成 MyBatis Plus,理解常用注解以及常见配置
  • 代码训练营第53天:动态规划part12|leetcode309买卖股票的最佳时期含冷静期|leetcode714买卖股票的最佳时机含手续费
  • vue表格列表导出excel
  • 中文编程开发语言工具系统化教程零基础入门篇和初级1专辑课程已经上线,可以进入轻松学编程
  • 【目标检测】Visdrone数据集和CARPK数据集预处理
  • SQL中的非重复计数(进阶)
  • 项目管理概论:什么是项目、项目管理的重要性、成功的标准包含什么以及相关笔记
  • Vue3响应式对象: ref和reactive
  • C++STL---Vector、List所要掌握的基本知识
  • RGB-T Salient Object Detection via Fusing Multi-Level CNN Features
  • python opencv之图像分割、计算面积
  • [cpp primer随笔] 14. 类的构造函数
  • Winsows QT5.15安装教程——组件务必要选上Sources
  • vue3动态引入图片(:src)
  • k8s中 pod 或节点的资源利用率监控
  • 【HarmonyOS】鸿蒙操作系统架构