table 表格转成 excell 导出

OK,功能非常简单,但是很实用啊!

依赖安装

这里我们需要安装两个依赖: xlsxfile-saver,就可以帮助我们实现功能了!

js 复制代码
 npm i xlsx file-saver

代码参考

导出方法
utils/index.js

js 复制代码
import * as XLSX from 'xlsx'
import FileSaver from 'file-saver'

export const exportExcel = (el, name) => {
  // 根据 table 生成一个工作表
  const worksheet = XLSX.utils.table_to_sheet(el)
  // 创建一个空工作簿
  const workbook = XLSX.utils.book_new()
  // 将工作表附加到工作簿
  XLSX.utils.book_append_sheet(workbook, worksheet, 'Sheet1', true)
  // 写入工作簿并返回文件   bookType(导出文件的文件格式)  type (返回值类型)
  const excelBuffer = XLSX.write(workbook, { bookType: 'xlsx', type: 'array' })
  const data = new Blob([excelBuffer], { type: 'application/octet-stream' })
  FileSaver.saveAs(data, name + '.xlsx')
}

注意:

以下是低版本导入方法,最新版本获取 XLSXundefined,建议统一按上述导入。

js 复制代码
import XLSX from 'xlsx'

index.vue

js 复制代码
<template>
	<div class="table">
		<el-table ref="elTab"></el-table>
	</div>
</template>

<script>
import { exportExcel } from "@utils/index.js"
export default {
	methods: {
		export() {
			exportExcel(this.refs.elTab.$el, "xxx");
		},
	}
}
</script>

效果展示

el-table 表格

excell 表格

题外话

在这里做一个提醒!!!

如果你用了 Element 的 table 组件,并且做了某一列固定,那么这时候导出会出现一个数据重复bug:导出的 excell 中包含重复的表格数据

正常表格是行排列组成的表格,而使用了 fixed 属性的表格,里面多了列排列组成的表格,就相当于一个 table 中包含了两组表格数据,所以导出就会出现两组相同的数据。

解决:

js 复制代码
export() {
	// 手动获取其中一组表格数据		el-table__fixed 是列组合数据
	let el = document.querySelector(".el-table__fixed")
	exportExcel(el, "xxx");
},
相关推荐
漂流瓶jz4 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫4 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
修己xj5 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端
袋鼠云数栈6 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries6 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment6 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
qcx236 小时前
【系统学AI】25 论文导读 ①:两篇改变 AI 的开山之作——Attention Is All You Need & ReAct
前端·人工智能·react.js·transformer
kyriewen7 小时前
大文件上传最全指南:分片、断点续传、秒传,一篇就够了
前端·javascript·面试
郑洁文8 小时前
基于Python的Web命令执行漏洞自动化检测系统
前端·python·网络安全·自动化
新酱爱学习8 小时前
手搓 10 个 Skill 后,我把重复劳动收敛成了一套零依赖 CLI 工具
前端·javascript·人工智能