news 2026/4/3 1:42:49

element-ui table高度自适应实现分享

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
element-ui table高度自适应实现分享

文章目录

    • 概要
    • 实现思路
    • 具体代码
      • 自适应封装mixins代码
      • 使用示例组件代码
    • 附加分享

概要

在后台管理系统开发过程中,通常我们的布局都是如下图。这里面比较头疼的问题就是右侧这个table的高度自适应问题,接下来我将分享如何简单实现表格高度自适应。

实现思路

1、表格高度=视口高度-头部搜索表单的高度-其他(margin/padding)
2、为了不每个组件都写那些计算的代码,提取一个mixins,要实现自适应引用下就行

具体代码

自适应封装mixins代码

首先那个toggleExpand方法不看。

1、组件第一次渲染算一次,第一次就不用防抖了;
2、然后就是注册resize事件,窗口尺寸变化再触发计算,这里要防抖啊;
3、里面查询表单的高度要动态获取,原因就是不同窗口尺寸表单项会出现换行的情况

exportdefault{data(){return{fixedHeight:120,tableHeight:undefined,resizeTimer:null,isExpanded:false}},mounted(){this.updateHeight()window.addEventListener('resize',this.resizeHandler)},beforeDestroy(){window.removeEventListener('resize',this.resizeHandler)},methods:{resizeHandler(){this.resizeTimer&&clearTimeout(this.resizeTimer)this.resizeTimer=setTimeout(()=>{this.updateHeight()},300)},updateHeight(){constformEl=document.querySelector('.header-form')constformHeight=formEl?formEl.offsetHeight:60this.tableHeight=window.innerHeight-this.fixedHeight-formHeight-20},toggleExpand(){this.isExpanded=!this.isExpandedthis.$nextTick(()=>{this.updateHeight()})}}}

使用示例组件代码

1、这里代码不兴放一半所以App代码也放在下面了;
2、使用步骤:
(1)、导入注册mixins
(2)、然后table height绑定tableHeight,这样就OK了

App组件代码

<template><div id="app"><divclass="header-container"></div><divclass="bottom-container"><divclass="bottom-left-container"></div><divclass="bottom-right-container"><User/></div></div></div></template><script>importUserfrom'@/views/User.vue'exportdefault{components:{User}}</script><style lang="less">#app{position:fixed;top:0;left:0;height:100%;width:100%;display:flex;flex-direction:column;.header-container{height:80px;background-color:#34495d;}.bottom-container{height:0;flex:1;display:flex;.bottom-left-container{width:200px;height:100%;background-color:#43bd87;}.bottom-right-container{height:100%;width:0;flex:1;overflow:auto;}}}</style>

User组件代码

<template><divclass="user-container"><el-form label-position="left"label-width="50px":model="formDtas"class="header-form"><el-row:gutter="20"><el-col:xs="24":sm="12":md="8":lg="6"><el-form-item label="姓名"><el-input v-model="formDtas.Name"></el-input></el-form-item></el-col><el-col:xs="24":sm="12":md="8":lg="6"><el-form-item label="年龄"><el-input v-model="formDtas.Age"></el-input></el-form-item></el-col><el-col:xs="24":sm="12":md="8":lg="6"><el-form-item label="姓名"><el-input v-model="formDtas.Name"></el-input></el-form-item></el-col><el-col:xs="24":sm="12":md="8":lg="6"><el-form-item label="年龄"v-if="isExpanded"><el-input v-model="formDtas.Age"></el-input></el-form-item><div v-else><el-button type="primary">查询</el-button><el-button type="text"@click="toggleExpand"class="expand-btn">{{isExpanded?'收起':'展开'}}<i:class="['el-icon-arrow-' + (isExpanded ? 'up' : 'down')]"></i></el-button></div></el-col></el-row><div v-if="isExpanded"><el-row:gutter="20"><el-col:xs="24":sm="12":md="8":lg="6"><el-form-item label="姓名"><el-input v-model="formDtas.Name"></el-input></el-form-item></el-col><el-col:xs="24":sm="12":md="8":lg="6"><el-form-item label="年龄"><el-input v-model="formDtas.Age"></el-input></el-form-item></el-col><el-col:xs="24":sm="12":md="8":lg="6"><div><el-button type="primary">查询</el-button><el-button type="text"@click="toggleExpand"class="expand-btn">{{isExpanded?'收起':'展开'}}<i:class="['el-icon-arrow-' + (isExpanded ? 'up' : 'down')]"></i></el-button></div></el-col></el-row></div></el-form><el-table:data="tableDatas"style="width: 100%"border:height="tableHeight"><el-table-column prop="Name"label="姓名"></el-table-column><el-table-column prop="Age"label="年龄"></el-table-column><el-table-column prop="Gender"label="性别"></el-table-column></el-table></div></template><script>importtableAutoHeightfrom'@/mixins/tableAutoHeight.js'exportdefault{mixins:[tableAutoHeight],data(){return{formDtas:{Name:'',Age:''},tableDatas:[{Name:'张三',Age:20,Gender:'男'},{Name:'王五',Age:30,Gender:'男'},{Name:'李四',Age:25,Gender:'女'},{Name:'老王',Age:25,Gender:'女'},{Name:'张三',Age:20,Gender:'男'},{Name:'王五',Age:30,Gender:'男'},{Name:'李四',Age:25,Gender:'女'},{Name:'老王',Age:25,Gender:'女'},{Name:'张三',Age:20,Gender:'男'},{Name:'王五',Age:30,Gender:'男'},{Name:'李四',Age:25,Gender:'女'},{Name:'老王',Age:25,Gender:'女'},{Name:'张三',Age:20,Gender:'男'},{Name:'王五',Age:30,Gender:'男'},{Name:'李四',Age:25,Gender:'女'},{Name:'老王',Age:25,Gender:'女'},{Name:'张三',Age:20,Gender:'男'},{Name:'王五',Age:30,Gender:'男'},{Name:'李四',Age:25,Gender:'女'},{Name:'老王',Age:25,Gender:'女'}]}},mounted(){},computed:{},methods:{},}</script><style scoped lang="less">.user-container{padding:20px;}</style>

附加分享

实现了表格自适应想处理下头部查询表单项换行的问题。这里就使用格栅布局。
思路:1、每行显示四列,折叠的情况下第一行最后一列就显示那个查询按钮,展开情况下第一行最后列就是表单项显示,按钮隐藏;2、超出四个的表单项都用一个div包起来(el-row超出会自动换行的),初始隐藏,展开就显示;3、触发展开/隐藏表格高度要重新算啊。
代码都在上面了,相信各位大佬肯定是看得懂的。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/3 1:41:32

Vue3+Cesium教程(37)--下雪啦!动态设置降雪效果

本学习系列以Cesium Vue3 Typescriptelementplus作为主要技术栈&#xff0c;后续会循序渐进&#xff0c;持续探索Cesium的高级功能&#xff0c;敬请期待。详情请查阅原文 Vue3Cesium教程(37)--下雪啦&#xff01;动态设置降雪效果https://mp.weixin.qq.com/s/5RFjzPKzkVLy_7h…

作者头像 李华
网站建设 2026/3/21 11:26:26

PX4导航遇到GPS数据丢失的处理和相关控制参数

PX4导航时GPS数据丢失的处理 1. GPS数据丢失的检测与驱动层处理 PX4的检测&#xff1a;GPS驱动通过poll()系统调用轮询接收数据&#xff0c;当超过1秒无有效数据时标记为不健康&#xff08;_healthyfalse&#xff09;重连&#xff1a;驱动会关闭并重启串口&#xff0c;在参数中…

作者头像 李华
网站建设 2026/3/30 5:42:30

星瞳OpenMV官方机械臂教程|从零开始:Robot Arm机械臂快速上手

欢迎观看OpenMV官方机械臂的第一期教程&#xff01;本期将带你快速了解机械臂并掌握基础操作。 看完后&#xff0c;你就能开始创建自己的专属项目啦&#xff01; OpenMV官方机械臂教程|从零开始快速上手*具体教程和源码可在星瞳科技OpenMV官网[OpenMV.cc]查看哦&#xff01; …

作者头像 李华
网站建设 2026/3/23 22:46:47

2026年会议纪要工具top9_工具_测评_ASR

2024 年高效语音处理方案推荐根据 IDC《2023 年中国人工智能语音转文字应用市场白皮书》&#xff0c;2023 年中国语音转文字市场规模达 87.6 亿元&#xff0c;同比增长 34.2%&#xff0c;企业级用户对实时转写、多语言支持的需求同比提升 41%。从微观来看&#xff0c;传统会议记…

作者头像 李华
网站建设 2026/3/31 7:58:21

构建“不崩溃”的嵌入式系统:防御性编程

一、为什么嵌入式系统更需要防御性编程 在嵌入式开发中,以下问题几乎人人都遇到过: 串口或总线数据格式异常,解析函数直接跑飞 函数被传入 NULL 指针,系统 HardFault 或复位 内存被意外覆盖,程序行为开始“玄学化” 这些问题的共同点只有一个:系统对“不可信输入”缺乏防…

作者头像 李华