news 2026/5/30 16:18:04

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/5/20 11:49:31

【2026年-03期】Collaborative evolution between AI and humans

这是一幅关于 AI 与人类协作进化的逻辑全景图&#xff0c;它梳理了从 AI 技术迭代到人类能力重塑&#xff0c;再到二者形成新协作模式的完整逻辑链条。AI 演进与人类能力的底层逻辑AI 演进的双轮驱动AI 演化速度&#xff1a;从 GPT-3 → GPT-4 → GPT-5&#xff0c;模型能力不断…

作者头像 李华
网站建设 2026/5/21 12:11:01

边界之内:为何高维内插无法催生下一次科学革命?

在一个被大数据和人工智能的承诺所笼罩的时代&#xff0c;一种信念日益深入人心&#xff1a;只要有足够的数据和强大的算法&#xff0c;我们就能自动解锁自然界最深邃的奥秘。机器学习模型在蛋白质折叠、材料发现和气候预测等领域取得的惊人成就&#xff0c;似乎都在为这一愿景…

作者头像 李华
网站建设 2026/5/20 17:58:16

Spring Boot 三种方式登录系统:集成微信扫码、短信验证码、邮箱验证码

Spring Boot 三种方式登录系统&#xff1a;集成微信扫码、短信验证码、邮箱验证码&#xff08;含高并发与安全增强&#xff09; 主要因为前面的帖子不太完整。 一、引言 在现代 Web 应用中&#xff0c;提供多种灵活、安全的登录方式已成为标配。本文档旨在提供一套生产就绪的…

作者头像 李华
网站建设 2026/5/30 9:45:15

HTML5 与 H5:别再让你的专业度在称呼中流失

在中国互联网行业的日常交流中&#xff0c;很少有一个词像“H5”这样被高频使用&#xff0c;却又被如此普遍地误解。当你听到有人说“做一个 H5”时&#xff0c;对方指的往往是一个在微信朋友圈传播的精美幻灯片&#xff0c;或者是一个简单的营销小游戏。然而&#xff0c;当你打…

作者头像 李华
网站建设 2026/5/21 10:31:48

3-VueAjax

什么是Vue Vue是一款用于构建用户界面的渐进式的JavaScript框架。官方网站&#xff1a;https://cn.vuejs.org/ 前端负责将数据以美观的样式呈现出来&#xff0c;而数据最终又要在数据库服务器中存储并管理。前端想要拿到数据&#xff0c;就需要请求服务器。然后服务器将数据返…

作者头像 李华
网站建设 2026/5/21 11:45:06

基于springBoot的房屋租赁管理系统

房屋租赁管理系统的背景意义 市场需求驱动 随着城市化进程加快&#xff0c;流动人口增多&#xff0c;房屋租赁需求持续增长。传统租赁方式依赖中介或线下沟通&#xff0c;效率低且信息不透明。数字化管理系统能优化流程&#xff0c;提升供需匹配效率&#xff0c;降低交易成本…

作者头像 李华