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

利用ExcelJS封装一个excel表格的导出

ExcelJS 操作和写入Excel 文件。
直接上代码,js部分:
exportFn.js

import ExcelJS from 'exceljs';
import { saveAs } from 'file-saver';export function exportExcleUtils(tHeader, filterVal, listData, fileName) {//设置工作簿属性const workbook = new ExcelJS.Workbook();workbook.creator = 'Me';workbook.lastModifiedBy = 'Her';workbook.created = new Date();workbook.modified = new Date();workbook.lastPrinted = new Date();//添加工作薄const worksheet = workbook.addWorksheet('sheet1');//计算标题宽let colWidth = calculateColumnWidth(tHeader);console.log(colWidth);let style = { alignment: { vertical: 'middle', horizontal: 'center' } };let columns = [];for (let i = 0; i < tHeader.length; i++) {let header = {header: tHeader[i],key: filterVal[i] ? filterVal[i] : i + '',width: colWidth[i] ? colWidth[i] + 20 : 10,style: JSON.parse(JSON.stringify(style)),};columns.push(header);}worksheet.columns = columns;//添加数据listData.forEach((item) => {worksheet.addRow(item);});worksheet.getRow(1).font = { name: '宋体', family: 4, size: 16, bold: true };fileName = fileName + '.xlsx';workbook.xlsx.writeBuffer().then((data) => {let blob = new Blob([data], {type: 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',});saveAs(blob, fileName);});
}export function calculateColumnWidth(tHeader) {let colWidth = [];//计算列宽for (let i = 0; i < tHeader.length; i++) {if (colWidth[i] && colWidth[i] < tHeader[i].length) {colWidth[i] = tHeader[i].length * 2;} else if (colWidth[i] === undefined) {colWidth[i] = tHeader[i].length * 2;}}return colWidth;
}

举个栗子:

//从公共函数中拿出
import { exportExcleUtils } from '@/libs/exportFn';
...
...
...
//再写个按钮<el-button type="primary" @click="exportFn">导出按钮</el-button>
...
...
...//导出exportFn() {let loadingInstance = Loading.service({text: '正在导出,请稍等...',});let table = this.selectedRowArr;//表头let tHeader = ['a','b','c','d',];//数据的里字段let filterVal = ['person','dog','cat','pig',];let fileName = '导出的表文件名';loadingInstance.close();exportExcleUtils(tHeader, filterVal, table, fileName);},

PS:上文的selectedRowArr变量是我项目里的,自己去塞数据,数组对象形式

http://www.lryc.cn/news/473905.html

相关文章:

  • AI 原生时代,更要上云:百度智能云云原生创新实践
  • C语言程序编译运行
  • 视频点播系统扩展示例
  • echo $? —— Linux 中的退出状态码详解
  • heic格式转化jpg最简单方法?快来学习这几种简单的转换方法!
  • 力扣(leetcode)每日一题 3259 超级饮料的最大强化能量|动态规划
  • Webserver(2.7)内存映射
  • vue3父子组件传值,子组件暴漏方法
  • Linux_04 Linux常用命令——tar
  • Java项目实战II基于Java+Spring Boot+MySQL的编程训练系统(源码+数据库+文档)
  • Rust:文档注释 //! 和 ///
  • 练习LabVIEW第二十七题
  • 使用React构建现代Web应用
  • 【系统设计】Merkle 算法在 Git 中的应用:深入理解与实践
  • 【umi max】关于umi构建的项目在本地服务运行正常,但是部署时无致命报错却白屏,html文档的#root容器没有子元素的原因及解决办法
  • Openlayers高级交互(14/20):汽车移动轨迹动画(开始、暂停、结束)
  • 蓝牙MCU蓝牙医疗检测相关案例
  • pytorch环境安装和更新,额外装cuda有什么意义
  • 【观成科技】APT组织常用开源和商业工具加密流量特征分析
  • Java开发者的Python快速进修指南:面向对象进阶
  • 【商汤科技-注册/登录安全分析报告】
  • 诱骗取电快充协议芯片,支持与其它 MCU 共用 D+D-网络和电脑传输数据
  • Java Executor ScheduledExecutorService 源码
  • 【力扣 + 牛客 | SQL题 | 每日6题】牛客SQL热题 + 力扣hard
  • 前端常见错误
  • Edge 浏览器插件开发:图片切割插件
  • 银河麒麟v10 xrdp安装
  • Leetcode 删除有序数组中的重复项 Ⅱ
  • 大模型学习笔记------什么是大模型
  • 【unique_str 源码学习】