使用 flex 简单实现 table 自适应页面

效果

  • 保证页面其他模块宽度高度自适应,动态改变中部 table 的高度

  • 当页面整体宽度较小,顶部搜索模块高度自动撑开时,table 宽度动态变小,只展示 4 行数据。

  • 当页面整体宽度较大,顶部搜索模块没那么高,table 高度自动变大,展示 7 行数据。

实现

  • 利用 el-table 的固定表头的特性,设置 el-table 的高度为 100%
  • 再利用 flex-grow 的特性,设置 el-table 的父盒子属性为 flex-frow: 1,自动分配空间内的剩余高度
  • 关键代码
css 复制代码
// 最外层根组件
.validateForm {
  height: 100%;
  display: flex;
  flex-direction: column;
  // el-table 的父盒子 - 设置 flex-grow,还需要设置一个最小高,表示该元素参与高度分配
  .table {
    min-height: 10px;
    flex-grow: 1;
  }
}
相关推荐
xsbcme3 小时前
VueTabRouter 插件实践(一):多标签页不是一排 TabBar
vue.js
jnene4 小时前
html 时间、价格筛选样式处理
前端·css·html
云水一下5 小时前
Vue.js从零到精通系列(三):组件化基础——Props、Emits、插槽与生命周期
前端·javascript·vue.js
用户059540174467 小时前
Redis 缓存过期不一致踩坑实录:一个 bug 让我排查了 3 小时,最终用 Pytest 自动化堵上漏洞
前端·css
英勇无比的消炎药7 小时前
少踩坑TinyVue插槽事件编码规范详解
vue.js
神明不懂浪漫8 小时前
【第三章】CSS(一)——基础选择器、CSS的属性
前端·css·html·css3
用户059540174468 小时前
localStorage清除策略踩坑实录:一个过期的token让我排查了3小时
前端·css
2401_868534788 小时前
5G和4G接入网对比介绍
vue.js
chushiyunen9 小时前
vue export default
前端·javascript·vue.js
北极星日淘10 小时前
可买免税店货物与安耐晒——特殊商品代购技术方案
javascript·vue.js·elementui