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

vue2+element-UI表格封装

针对表格进行封装在列表页面直接传入字段数组就可以展示数据表templatedivclasstable-container:class{ show-vertical-lines: showVerticalLines }!--数据表格--el-table reftableRef:datatableDataborder sizeministylewidth: 100%:max-heighttableHeightrow-keyid:row-class-namerowClassNamehighlight-current-row!--单选框列--el-table-column v-ifshowRadiowidth55aligncentertemplate slot-scopescopeel-radio v-modelradioSelection:labelscope.row.idchangehandleRadioChange(scope.row)nbsp;/el-radio/template/el-table-column!--多选框列--el-table-column v-ifshowSelectiontypeselectionwidth55aligncenter/el-table-column!--序号列--el-table-column v-ifshowIndextypeindexlabel序号width60aligncentertemplate slot-scopescope{{scope.$index1}}/template/el-table-column!--动态列--el-table-column v-for(column, index) in columns:keycolumn.prop || index:propcolumn.prop:labelcolumn.label:widthcolumn.width:min-widthcolumn.minWidth || 80:header-aligncolumn.headerAlign || left:aligncolumn.align || left:fixedcolumn.fixedtemplate slot-scopescope!--作用域插槽允许父组件自定义内容--slot:namecolumn.prop:rowscope.row:editableisRowEditable(scope.row)!--默认渲染逻辑--template v-ifisRowEditable(scope.row) column.editable trueel-input v-modelscope.row[column.prop]sizesmallblurhandleInputBlur(scope.row, column.prop)click.native.stop/el-input/templatetemplate v-else!--超长文本省略--el-tooltip v-ifscope.row[column.prop] scope.row[column.prop].toString().length 100:contentscope.row[column.prop]placementtopeffectdarkdivclassellipsis-text{{scope.row[column.prop]}}/div/el-tooltipspan v-else{{scope.row[column.prop]}}/span/template/slot/template/el-table-column/el-table!--分页--divclasspagination-fixedel-pagination size-change$emit(size-change, $event)current-change$emit(current-change, $event):current-pagecurrentPage:page-sizes[10, 20, 50, 100]:page-sizepageSizelayouttotal, sizes, prev, pager, next, jumper:totaltotalbackground styletext-align:right;/el-pagination/div/div/templatescriptexportdefault{name:TableContainer,props:{tableData:{type:Array,default:()[]},columns:{type:Array,default:()[]},currentPage:{type:Number,default:1},pageSize:{type:Number,default:10},total:{type:Number,default:0},showSelection:{type:Boolean,default:false},showRadio:{type:Boolean,default:false},showIndex:{type:Boolean,default:false},showVerticalLines:{type:Boolean,default:false},// 新增允许父组件传入表格距离顶部的偏移量默认 260pxoffsetTop:{type:Number,default:260}},data(){return{radioSelection:null,tempBackup:null,// 新增用于存储当前正在编辑行的快照tableHeight:400};},mounted(){this.$nextTick((){this.calculateTableHeight();});window.addEventListener(resize,this.calculateTableHeight);},beforeDestroy(){window.removeEventListener(resize,this.calculateTableHeight);},methods:{rowClassName({row}){returnthis.radioSelectionrow.id?radio-selected:;},isRowEditable(row){returnthis.radioSelectionrow.id;},// 核心逻辑处理单选框切换handleRadioChange(currentRow){// 1. 恢复上一行的数据 (如果存在上一行且备份存在)if(this.tempBackup){// 找到表格数据中对应的那一行对象constprevRowDatathis.tableData.find(itemitem.idthis.tempBackup.id);if(prevRowData){// 用备份的数据覆盖当前表格中的数据撤销修改Object.assign(prevRowData,JSON.parse(JSON.stringify(this.tempBackup)));}}// 2. 为当前点击的这一行创建新的备份// 注意这里必须深拷贝否则 tempBackup 会跟着表格数据一起变this.tempBackupJSON.parse(JSON.stringify(currentRow));// 3. 触发外部事件this.$emit(radio-change,currentRow);},handleInputBlur(row,prop){this.$emit(input-blur,row,prop);},calculateTableHeight(){// 方式一基于窗口高度减去固定偏移量简单粗暴// this.tableHeight window.innerHeight - this.offsetTop;// 方式二更精准的计算推荐// 获取表格容器相对于视口的位置constrectthis.$el.getBoundingClientRect();// 视口高度 - 表格顶部距离 - 分页高度(约50) - 底部留白(20)this.tableHeightwindow.innerHeight-rect.top-70;// 设置最小高度防止过小if(this.tableHeight200)this.tableHeight200;}},emits:[size-change,current-change,radio-change,input-blur]};/scriptstyle scoped.table-container{width:100%;position:relative;background-color:#fff;/* border-radius: 4px; *//* box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08); */overflow:hidden;}.el-table{width:100%;margin:0;}/* 核心调整行高缩小至 24px与文字大小一致 */.el-table__row{height:24px!important;}.el-table__cell{padding:012px;/* 上下padding设为0仅保留左右 */line-height:1.2;vertical-align:middle;/* 确保垂直居中 */}/* 确保表头高度也同步缩小 */::v-deep.el-table th{height:24px!important;line-height:24px!important;background-color:#f0f2f5!important;font-weight:600!important;user-select:text!important;}/* 消除单元格底部多余边框间距 */::v-deep.el-table--border::after,::v-deep.el-table--group::after,::v-deep.el-table::before{height:0;}.pagination-fixed{margin-top:0;display:flex;justify-content:flex-end;align-items:center;padding:6px0;background-color:#fff;}.banner-image{max-width:100px;max-height:50px;}.radio-selected{background-color:#f0f9eb!important;}.ellipsis-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%;display:inline-block;}/* 隐藏表格竖线 */.table-container:not(.show-vertical-lines)::v-deep.el-table th,.table-container:not(.show-vertical-lines)::v-deep.el-table td{border-right:none!important;border-left:none!important;}.table-container:not(.show-vertical-lines)::v-deep.el-table--border,.table-container:not(.show-vertical-lines)::v-deep.el-table--group{border-right:none!important;border-left:none!important;}/style传入字段数组格式data(){return{tableData:[],columns:[{prop:title,label:标题,minWidth:80},{prop:introduction,label:内容简介,minWidth:200},{prop:publishTime,label:发布时间,minWidth:80},{prop:status,label:状态,minWidth:50},{prop:createTime,label:创建时间,minWidth:80},{prop:createBy,label:创建人,minWidth:80},{prop:action,label:操作,minWidth:80,headerAlign:center,align:center}],currentPage:1,pageSize:10,total:0,};},调用方式table-container:table-datatableData:columnscolumns:current-pagecurrentPage:page-sizepageSize:totaltotal:base-urlbaseUrl:show-selectionfalse:show-indextruesize-changehandleSizeChangecurrent-changehandleCurrentChangetemplate #status{ row }span v-ifrow.status 1stylecolor:#13ce66已发布/spanspan v-elsestylecolor:#ff4949未发布/span/templatetemplate #createBy{ row }span v-ifrow.createBy{{getCreateUser(row)}}/span/templatetemplate #action{ row }el-button v-ifrow.status 0typetextclickhandleEdit(row)编辑/el-buttonspan v-ifrow.status 0stylemargin:0 8px;color:#ddd|/spanel-button v-ifrow.status 0typetextclickhandlePublish(row)发布/el-buttonspan v-ifrow.status 0stylemargin:0 8px;color:#ddd|/spanel-button v-ifrow.status ! 0typetextclickhandlePreview(row)预览/el-buttonspan v-ifrow.status ! 0stylemargin:0 8px;color:#ddd|/spanel-button typetextclickhandleDelete(row.id)删除/el-button/template/table-container/div

相关文章:

vue2+element-UI表格封装

针对表格进行封装&#xff0c;在列表页面直接传入字段数组就可以展示数据表&#xff1a; <template><div class"table-container" :class"{ show-vertical-lines: showVerticalLines }"><!-- 数据表格 --><el-table ref"tableRe…...

MIPI-DSI协议解析:从物理层到应用层的LCD驱动实践

1. MIPI-DSI协议基础&#xff1a;显示接口的"高速公路" 第一次接触MIPI-DSI时&#xff0c;我盯着开发板上那几根细如发丝的走线发愣——这么少的线路怎么传输高清图像&#xff1f;后来才明白&#xff0c;这正是MIPI-DSI的精妙之处。作为移动设备显示接口的事实标准&…...

从PID调参到根轨迹:一个电机控制工程师的实战避坑笔记

从PID调参到根轨迹&#xff1a;一个电机控制工程师的实战避坑笔记 作为一名在工业自动化领域摸爬滚打多年的电机控制工程师&#xff0c;我深知PID参数调试的痛点和挑战。每当面对一个全新的电机控制系统&#xff0c;传统的试凑法不仅耗时耗力&#xff0c;还常常陷入"调好一…...

MT7916芯片深度解析:从拆机中兴E1630看MTK首款AX3000方案

1. 拆机中兴E1630&#xff1a;MT7916芯片的首次亮相 最近在闲鱼上看到中兴E1630这款路由器&#xff0c;价格209元入手&#xff0c;虽然有点小贵&#xff0c;但为了第一时间给大家带来拆机评测还是值得的。这款中国电信定制版路由器外包装略显陈旧&#xff0c;但内部设备保存完好…...

软件测试核心概念实战解析:从理论到习题的深度贯通

1. 软件测试基础理论的核心要点 软件测试作为软件开发过程中不可或缺的一环&#xff0c;其理论基础直接影响着测试工作的质量和效率。在软件测试领域&#xff0c;有几个核心概念是每个测试人员都必须掌握的。 首先&#xff0c;我们需要理解软件生命周期这个概念。简单来说&…...

OP-TEE安全存储深度解析(一):密钥层级与文件加密流程

1. 密钥管理器的核心角色 在OP-TEE的安全存储架构中&#xff0c;密钥管理器就像是一个高度戒备的金库管理员。它不直接存储用户数据&#xff0c;而是负责生成、保护和调度所有用于加密的密钥。这个设计非常巧妙——即使攻击者突破了外层防御&#xff0c;拿到的也只是加密后的数…...

ESP32-C3 蓝牙应用实战:从零构建一个自定义 GATT 服务

1. 环境准备&#xff1a;搭建ESP32-C3开发环境 第一次接触ESP32-C3蓝牙开发的朋友可能会觉得无从下手&#xff0c;其实只要把开发环境搭好就成功了一半。我刚开始用Windows系统开发时踩过不少坑&#xff0c;后来发现用VSCode配合官方ESP-IDF工具链最省心。 首先需要安装乐鑫官方…...

6.6 实战解析——破解可转债数据爬取难题(XPath精准定位与Selenium登录失效的应对策略)

1. 可转债数据爬取的核心挑战 最近在做一个金融数据分析项目时&#xff0c;需要获取可转债的实时行情数据。我首先想到的就是从集思录这类专业网站抓取数据&#xff0c;但实际操作中发现几个棘手的问题。最让人头疼的是&#xff0c;明明用Selenium模拟登录成功了&#xff0c;却…...

ISO 15118-20:2022 深度解读:第二代车网通信接口如何重塑智能充电与电网互动

1. ISO 15118-20:2022标准的前世今生 第一次听说ISO 15118这个标准时&#xff0c;我正蹲在充电站调试一台死活连不上充电桩的电动车。当时满脑子都是"为什么连个充电都要搞这么复杂&#xff1f;"后来才知道&#xff0c;这背后藏着整个电动汽车与电网对话的密码。ISO…...

Unity Shader 中 ShadowCaster的作用和疑问

1. ShadowCaster&#xff08;核心 —— 让物体能投影&#xff09;LightMode ShadowCaster&#xff1a;URP 渲染 Shadow Map 时会调用此 PassColorMask 0&#xff1a;不输出颜色&#xff0c;只写深度顶点关键步骤&#xff1a;TransformObjectToWorld / TransformObjectToWorldN…...

计算机毕业设计:Python农作物产量智能预估与数据看板 Flask框架 XGBoost 机器学习 数据分析 可视化 大数据 大模型(建议收藏)✅

1、项目介绍 技术栈 采用 Python 语言开发&#xff0c;基于 Flask 框架搭建后端服务&#xff0c;使用 MySQL 数据库进行数据存储&#xff0c;通过 pymysql 连接数据库&#xff0c;运用 XGBoost 机器学习模型实现产量预测&#xff0c;前端结合 HTML、CSS、JavaScript、Echarts 和…...

【智能代码生成×代码度量双引擎实战指南】:20年架构师亲授如何用AI写代码+量化质量,规避97%的交付返工风险

第一章&#xff1a;智能代码生成代码度量双引擎协同范式 2026奇点智能技术大会(https://ml-summit.org) 传统AI编程辅助工具常将代码生成与质量评估割裂为独立流程&#xff1a;生成模型输出后&#xff0c;再由静态分析器进行滞后性度量。双引擎协同范式则打破这一时序壁垒&…...

从源码到实战:手把手教你编译与定制化iperf网络性能测试工具

1. iperf工具简介与适用场景 iperf是一款经典的开源网络性能测试工具&#xff0c;它通过测量TCP/UDP带宽来评估网络质量。我第一次接触这个工具是在调试嵌入式设备的网络吞吐量时&#xff0c;当时需要验证百兆网口的实际传输速率是否达标。相比简单的ping命令&#xff0c;iperf…...

基于西门子PLCS7-1200的程序仿真立体车库设计报告(含硬件原理图和CAD)

立体车库设计&#xff0c;基于西门子plcs7-1200带程序仿真&#xff0c;报告&#xff08;过1w&#xff09;&#xff0c;硬件原理图和cad 功能具体如下: 地面层配备七个停车位的升降系统能够有效执行车位的垂直转移在该层&#xff0c;四个停车位安装有自动升降装置&#xff0…...

【雷达成像】基于二维ADMM的稀度驱动ISAR成像附Matlab复现含文献

​✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长毕业设计辅导、数学建模、数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f447; 关注我领取海量matlab电子书…...

hermes agent 初体验

一、安装 参考链接&#xff1a;https://dashscope.aliyuncs.com/compatible-mode 二、报错及解决 问题1&#xff1a;WSL2安装报错 我是WSL2安装的&#xff0c;期间报错&#xff1a;Failed to install uv。我并没有按照他的要求手动去安装&#xff0c;而是再次执行&#xff1a;c…...

AI代码配额=新型IT预算?2026奇点大会披露:头部企业已将配额消耗纳入DevOps成本中心KPI(含真实财务映射表)

第一章&#xff1a;2026奇点智能技术大会&#xff1a;AI代码配额管理 2026奇点智能技术大会(https://ml-summit.org) 配额管理的核心挑战 随着大模型驱动的AI编程工具在企业级开发流程中深度集成&#xff0c;未经约束的自动代码生成正引发资源过载、安全策略失焦与合规审计失…...

从零手搓SM3国密算法:用C++一步步实现哈希函数(附完整可运行代码)

从零手搓SM3国密算法&#xff1a;用C一步步实现哈希函数&#xff08;附完整可运行代码&#xff09; 密码学算法的魅力在于&#xff0c;它用数学的确定性构建了数字世界的安全基石。当我们谈论哈希函数时&#xff0c;开发者往往满足于调用现成的库函数&#xff0c;却错过了理解算…...

别再只输密码了!手把手带你用Wireshark抓包,亲手‘看见’WPA2的四次握手过程(含过滤技巧)

无线网络安全实战&#xff1a;用Wireshark解析WPA2四次握手全流程 家里WiFi突然连不上&#xff1f;明明密码正确却反复提示认证失败&#xff1f;作为网络工程师&#xff0c;我遇到过太多次同事抱怨"路由器抽风"&#xff0c;而真相往往藏在那些看不见的数据帧里。今天…...

【奇点2026白皮书核心章节】:为什么83.6%的AI合并失败源于AST抽象层级错配?附可审计的合并决策树V2.1模板

第一章&#xff1a;AST抽象层级错配&#xff1a;AI代码合并失败的根因解构 2026奇点智能技术大会(https://ml-summit.org) AST&#xff08;Abstract Syntax Tree&#xff09;是现代AI代码工具理解、生成与重构程序的核心中间表示。然而&#xff0c;当多个AI代理协同执行代码合…...

21天回款950万!拆解素人铺量狂赚的底层逻辑

各位老板、运营操盘手&#xff0c;是不是觉得现在的电商营销越来越像一场豪赌&#xff1f;要么砸重金赌大主播的瞬间爆发&#xff0c;要么烧钱赌信息流的精准推送。结果往往是&#xff1a;流水看起来很猛&#xff0c;利润一算就头疼。今天不聊虚的&#xff0c;我们从市场化运营…...

信息学奥赛一本通 1248:Dungeon Master | 三维迷宫搜索算法精讲

1. 三维迷宫搜索算法入门&#xff1a;从Dungeon Master开始 第一次看到《Dungeon Master》这个题目时&#xff0c;我完全被三维迷宫的概念震撼到了。相比常见的二维迷宫&#xff0c;这个题目要求我们在一个立体的空间中寻找最短路径&#xff0c;就像被困在一个真实的地牢里一样…...

MATLAB条形图进阶:从基础bar函数到数据可视化实战

1. MATLAB条形图基础&#xff1a;从bar函数入门 第一次接触MATLAB的条形图功能时&#xff0c;我也曾被各种参数搞得晕头转向。但后来发现&#xff0c;只要掌握几个核心概念&#xff0c;就能快速上手这个强大的数据可视化工具。bar函数就像是一个万能画笔&#xff0c;能帮我们把…...

Zotero-OCR插件:3步实现PDF文献智能识别与可搜索文本层添加

Zotero-OCR插件&#xff1a;3步实现PDF文献智能识别与可搜索文本层添加 【免费下载链接】zotero-ocr Zotero Plugin for OCR 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-ocr Zotero-OCR是Zotero文献管理软件的功能扩展插件&#xff0c;专门为PDF文档添加可搜索…...

从滤波到优化:手把手拆解VIO算法核心,看懂OpenVINS的MSCKF和ORB-SLAM3的BA到底差在哪

从滤波到优化&#xff1a;手把手拆解VIO算法核心&#xff0c;看懂OpenVINS的MSCKF和ORB-SLAM3的BA到底差在哪 视觉惯性里程计&#xff08;VIO&#xff09;技术近年来在机器人导航、增强现实等领域展现出强大的生命力。对于开发者而言&#xff0c;理解不同技术流派的核心差异&am…...

从CH344Q出发:打造高性能USB转4路TTL串口模块的设计实践

1. CH344Q芯片选型与核心优势 第一次接触CH344Q这颗芯片是在去年做一个工业数据采集项目的时候。当时需要同时连接4个不同波特率的传感器设备&#xff0c;市面上常见的USB转串口模块要么速度跟不上&#xff0c;要么稳定性堪忧。折腾了好几款方案后&#xff0c;同事推荐了沁恒的…...

CSS如何实现Less颜色函数自动计算渐变_使用lighten与darken实现视觉反馈

lighten() 和 darken() 按 HSL 的 L 分量线性调整亮度&#xff0c;非像素级明暗处理&#xff1b;需确保输入为 color 类型、慎用于高饱和色、避免链式调用&#xff0c;并配合 saturate 等增强视觉反馈。lighten() 和 darken() 在 Less 中怎么写才不翻车Less 的 lighten() 和 da…...

罗茨风机行业专题研究:全国知名风机大品牌终身有保障的

随着我国工业现代化进程加速及环保政策趋严&#xff0c;罗茨风机作为污水处理、电力、化工等领域的关键设备&#xff0c;市场需求持续增长。据中国通用机械工业协会统计&#xff0c;2024年我国罗茨风机市场规模达82.3亿元&#xff0c;年复合增长率7.5%&#xff0c;行业呈现技术…...

Markdown转docx 保留Latex渲染样式

需求分析 Markdown转docx有大量公式。包括行内公式和行间公式Office 自带的数学与 Latex的渲染样式存在差异。本文倾向于使用Latex的渲染样式轻量调整。转换后仅做轻微的调整&#xff0c;不再编辑公式。 选择方案 主要编辑在Markdown&#xff0c;使用Latex渲染样式&#xff…...

LabVIEW虚拟数字示波器:从仿真到实战的信号分析平台

1. LabVIEW虚拟数字示波器&#xff1a;你的信号分析瑞士军刀 第一次接触LabVIEW虚拟数字示波器时&#xff0c;我正被实验室排队等设备的同学们逼得焦头烂额。直到发现用LabVIEW自己搭建的数字示波器&#xff0c;不仅能随时调用&#xff0c;还能自定义各种高级功能&#xff0c;简…...