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

概述

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

相关推荐
yqcoder26 分钟前
Node.js 与 JavaScript 是什么关系
开发语言·javascript·node.js
贵州晓智信息科技1 小时前
Three.js实现动态水泡效果逐步解析GLSL着色器
开发语言·javascript·着色器
老K(郭云开)1 小时前
最新版Edge浏览器加载ActiveX控件技术——allWebPlugin中间件之awp_CreateActiveXObject接口用法
前端·javascript·chrome·中间件·edge
一点一木2 小时前
从零开始:使用 Brain.js 创建你的第一个神经网络(一)
前端·javascript·人工智能
小璇玑学前端2 小时前
微信小程序地图,定位,仿多多自提点
前端
我的div丢了肿么办2 小时前
vue3.5的更新保证你看的明明白白
前端·javascript·vue.js
愚z2 小时前
WorkboxWebpackPlugin 使用指南
前端
带多刺的玫瑰2 小时前
Leecode刷题C语言之统计打字方案数
javascript·数据结构·算法
m0_748248652 小时前
详细介绍Sd-WebUI提示词的语法规则
前端
南北极之间2 小时前
前端新手必看:10 大 UI 组件库全面解析,快速搭建高质量 Web 应用」 「从零开始:Vue 和 React 最受欢迎的 UI 组件库入门指南」 「超实用!PC 端和移动端 UI 组件库推荐与实战
前端·vue.js·ui·elementui·element·anti-design-vue·ui组件库