Vue.js 动态设置表格最大高度的实现

server/2025/1/21 21:27:11/
概述

在现代 Web 开发中,响应式设计至关重要,尤其是在处理复杂的布局和数据表格时。表格通常会受到多种因素的影响,如分页、合计行或动态内容,这可能导致表格高度的变化。本文将介绍一个基于 Vue.js 的方法 setMaxHeight,该方法动态计算和设置表格的最大高度,确保表格始终能在可视区域内显示,而不受其它元素的干扰。

目标
  • 通过计算可用空间并自动调整表格高度,确保表格显示在合适的区域内。
  • 动态处理不同布局和页面元素的高度变化,如分页、合计行等。
  • 提供可维护、可扩展的解决方案,适应不同表格组件库(如 el-tableivu-table)的要求。
代码分析
javascript">export default {data() {return {maxHeight: 0,  // 表格最大高度};},methods: {/*** 动态计算表格最大高度* 1. 根据容器的总高度减去非表格元素的高度来计算表格的最大高度* 2. 支持分页、合计行等因素的动态变化* * @param {HTMLElement} e - 表格容器元素*/setMaxHeight(e) {if (!e) return;  // 如果未传入容器元素,直接返回// 过滤掉表格本身(ivu-table-wrapper、el-table)以及v-resize生成的object节点const otherEle = Array.from(e.children).filter(item => !item.classList.contains('ivu-table-wrapper') && !item.classList.contains('el-table') && item.nodeName !== 'OBJECT');// 计算过滤后的其它元素的高度之和const otherHeight = otherEle.reduce((sum, item) => sum + item.clientHeight, 0);// 判断表格是否包含合计行const hasSummary = Array.from(e.children)[0].classList.contains('ivu-table-with-summary');// 计算表格最大高度this.maxHeight = e.clientHeight - otherHeight - (hasSummary ? 36 : 0);},},
};
代码逻辑
  1. 初始化数据: 在 Vue 组件的 data 中,定义一个 maxHeight 属性来存储计算得到的最大表格高度。

  2. setMaxHeight 方法

    • 参数说明:方法接受一个 DOM 元素 e,该元素通常是包含表格及其他子元素的容器。
    • 判断空值:首先检查是否传入有效的容器元素 e,如果为空,直接返回。
  3. 过滤非表格节点

    • 使用 Array.frome.children 转化为数组,并通过 filter 方法排除掉类名为 ivu-table-wrapperel-table 的子元素,以及 OBJECT 类型的节点(可能是由 v-resize 或其他插件生成的用于调整大小的元素)。
  4. 计算其它元素的总高度

    • 通过 reduce 方法遍历所有非表格元素,并累加它们的 clientHeight,即元素的可视高度。
  5. 检查是否包含合计行

    • 检查表格容器的第一个子元素是否包含 ivu-table-with-summary 类名来判断是否显示合计行。如果存在合计行,额外减去 36px。
  6. 计算最大高度

    • 最终,通过减去非表格元素的总高度以及合计行的高度(如果有的话),计算出表格的最大高度 maxHeight,并将其赋值给组件的数据属性 maxHeight
使用场景

此方法适用于需要动态调整表格高度的场景,尤其是在以下情况下:

  • 页面布局中包含分页元素,且分页高度可能会动态变化。
  • 表格中可能包含合计行或其他特殊行,需要在计算表格高度时考虑其额外占用的空间。
  • 表格容器的高度是固定的,但内部内容可能会随时间或用户交互而变化,导致表格需要重新调整高度。
示例

假设你在 Vue 组件中使用了 el-tableivu-table,并希望根据容器的高度动态设置表格的最大高度:

javascript"><template><div class="table-container" ref="tableContainer" @resize="setMaxHeight($refs.tableContainer)"><el-table :data="tableData" :max-height="maxHeight"><!-- 表格内容 --></el-table></div>
</template><script>
import { ref, onMounted } from 'vue';export default {setup() {const tableData = ref([]);const maxHeight = ref(0);onMounted(() => {// 在组件挂载完成后,初始化最大高度this.setMaxHeight(this.$refs.tableContainer);});return {tableData,maxHeight,setMaxHeight,};},
};
</script>
性能优化
  1. 减少不必要的 DOM 操作

    • 在每次页面大小或布局变化时调用 setMaxHeight 方法时,确保只进行必要的 DOM 查询和计算。可以考虑节流(throttle)或防抖(debounce)技术,避免频繁执行。
  2. 缓存结果

    • 如果表格容器的大小变化不频繁,可以考虑缓存计算结果,避免重复计算。
总结

setMaxHeight 方法是一个实用的解决方案,帮助开发者动态调整表格的最大高度,确保表格在各种布局下都能自适应地显示。通过过滤非表格节点、计算其它元素的高度并考虑合计行的影响,能够灵活地处理复杂的布局和交互场景。


http://www.ppmy.cn/server/160284.html

相关文章

新能源科技亲民化路径何在?交互式展厅提供新解吗?

在当今科技迅猛发展的时代&#xff0c;全球能源需求持续增长&#xff0c;新能源的崛起既筑起了环保防线&#xff0c;又开启了能源新纪元。然而&#xff0c;新能源技术的复杂性常令非技术背景的公众难以理解和应用。为此&#xff0c;新能源主题交互式展厅应运而生&#xff0c;成…

解密AIGC三大核心算法:GAN、Transformer、Diffusion Models原理与应用

在当今数字化时代&#xff0c;人工智能生成内容&#xff08;AIGC&#xff09;技术正以前所未有的速度改变着我们的生活和工作方式。从创意无限的文本生成&#xff0c;到栩栩如生的图像创作&#xff0c;再到动听的音乐旋律&#xff0c;AIGC的魔力无处不在。而这一切的背后&#…

mysql的测试方案

1. 测试目标与范围 1.1 性能测试目标 MySQL性能测试旨在评估数据库在不同负载条件下的响应速度、吞吐量和资源利用率&#xff0c;确保其能够满足业务需求。 响应时间&#xff1a;衡量查询和事务处理的延迟&#xff0c;目标是将平均响应时间控制在100毫秒以内&#xff0c;95%的…

2025美赛Latex模板可直接运行!O奖自用版

目录 01 预览图02 Latex模板main.texeasymcm.sty 2025年美国大学生数学建模大赛&#xff08;2025年1月23日&#xff09;马上开始啦&#xff0c;大家一定要提前准备好模板&#xff0c;Latex或者是Word都可以&#xff0c;这里我整理了之前比赛用到的模板&#xff0c;并进行了一些…

PyTorch框架——基于深度学习YOLOv11神经网络路面坑洞检测系统

基于深度学习YOLOv11神经网络路面坑洞检测系统&#xff0c;其能识别路面坑洞&#xff0c;见如下 第一步&#xff1a;YOLOv11介绍 YOLOv11是由Ultralytics公司开发的新一代目标检测算法&#xff0c;它在之前YOLO版本的基础上进行了显著的架构和训练方法改进。以下是YOLOv11的一…

基于视觉分析的占道经营行为识别

随着城市化进程的加快&#xff0c;街头的占道经营现象逐渐增多。无论是在繁华的商业区&#xff0c;还是在居民区附近&#xff0c;占道经营都可能影响交通流畅、阻碍行人通行&#xff0c;甚至对城市的环境和形象造成负面影响。因此&#xff0c;如何有效地进行占道经营行为的检测…

基于单片机的智能家居控制系统设计及应用

摘要 : 智能家居控制系统包括对家电实现远距离控制和近距离控制的一种控制型系统,通过系统内的 TC35 模块对控制信息进行采集,并将这些控制信息发送到 STC89C52 模块中去,由单片机发出系统控制指令,从而实现家居家电的控制。 关键词 :单片机 ; 智能家居 ; 家居生活 ; 控…

MySQL入门(数据库、数据表、数据、字段的操作以及查询相关sql语法)

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…