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

vue3+elementUiPlus表格导出功能

1.下载需要的组件包

npm install file-saver xlsx

2.页面中导入

import FileSaver from 'file-saver'
import * as XLSX from 'xlsx';

 3.页面中的表格加一个id

<el-table
        :data="tableData"
        ref="multipleTableRef"
        style="width: 100%"
id="my-table">

        为了方法连接

4. 导出按钮

<el-button type="primary" icon="download" @click="exportClick ">导出</el-button>

 5.导出方法

const exportClick = () => {var table = document.querySelector('#my-table');// 复制表格,不包括第一列和最后一列var clonedTable = table.cloneNode(true);clonedTable.querySelectorAll('tr').forEach(row => {var cells = row.cells;if (cells.length > 0) {// 删除每行的第一个单元格row.deleteCell(0);// 删除每行的最后一个单元格row.deleteCell(cells.length - 1);}});// 创建一个新的工作簿var wb = XLSX.utils.book_new();// 创建一个新的工作表var ws = XLSX.utils.table_to_sheet(clonedTable);// 调整每列的列宽以适应内容autoSizeColumns(ws);// 将工作表添加到工作簿中XLSX.utils.book_append_sheet(wb, ws, 'Sheet1');// 导出工作簿const wbout = XLSX.write(wb, {bookType: 'xlsx',bookSST: true,type: 'binary',cellStyles: true, // 启用单元格样式});try {FileSaver.saveAs(new Blob([s2ab(wbout)], { type: 'application/octet-stream' }), '客户表.xlsx');} catch (e) {if (typeof console !== 'undefined') console.log(e, wbout);}
};

6.将字符串转为数组

// 将字符串转换为字节数组
function s2ab(s) {const buf = new ArrayBuffer(s.length);const view = new Uint8Array(buf);for (let i = 0; i < s.length; i++) {view[i] = s.charCodeAt(i) & 0xFF;}return buf;
}

7.计算最大列宽

function autoSizeColumns(ws) {const range = XLSX.utils.decode_range(ws['!ref']);for (let C = range.s.c; C <= range.e.c; ++C) {let maxColWidth = 0;for (let R = range.s.r; R <= range.e.r; ++R) {const cellAddress = { c: C, r: R };const cellRef = XLSX.utils.encode_cell(cellAddress);const cell = ws[cellRef];if (cell && cell.v) {const cellText = cell.w || cell.v.toString();const cellWidth = cellText.length + 2; // 加 2 以适应列头和数据if (cellWidth > maxColWidth) {maxColWidth = cellWidth;}}}const colWidth = maxColWidth > 20 ? maxColWidth : 20; // 设置最小列宽const col = ws['!cols'][C];if (col) {col.wch = colWidth;} else {ws['!cols'][C] = { wch: colWidth };}}
}

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

相关文章:

  • 专题五:优先级队列
  • 游戏设计模式专栏(一):工厂方法模式
  • element中使用el-steps 进度条效果demo(整理)
  • 038:mapboxGL 旋转地图(rotateTo)
  • java遇到的问题
  • LLM(二)| LIMA:在1k高质量数据上微调LLaMA1-65B,性能超越ChatGPT
  • Android AMS——创建Application(七)
  • html 边缘融合加载
  • ElasticSearch - 在 微服务项目 中基于 RabbitMQ 实现 ES 和 MySQL 数据异步同步(考点)
  • Springboot+vue的企业人事管理系统(有报告),Javaee项目,springboot vue前后端分离项目。
  • 初识Java 11-1 函数式编程
  • 【Ambari】银河麒麟V10 ARM64架构_安装Ambari2.7.6HDP3.3.1问题总结
  • 李宏毅机器学习第一课(结尾附作业模型详细分析)
  • 对日项目工作总结
  • 设计模式探索:从理论到实践的编码示例 (软件设计师笔记)
  • 【内网穿透】在Ubuntu搭建Web小游戏网站,并将其发布到公网访问
  • 在cesuim上展示二维模型
  • c/c++中如何输入pi
  • python爬虫:JavaScript 混淆、逆向技术
  • Vue error:0308010C:digital envelope routines::unsupported
  • gitee 远程仓库操作基础(一)
  • DRM全解析 —— ADD_FB2(0)
  • 01Redis的安装和开机自启的配置
  • 进入IT行业:选择前端开发还是后端开发?
  • Java集成Onlyoffice以及安装和使用示例,轻松实现word、ppt、excel在线编辑功能协同操作,Docker安装Onlyoffice
  • 编程面试_动态规划
  • ip地址可以精确定位吗
  • Xamarin体验:使用C#开发iOS/Android应用
  • 聊聊druid连接池的监控
  • CentOS 7 安装 Docker 的详细步骤