解决element的Table表格组件的高度自适应问题

解决element的Table表格组件的高度自适应问题

目的

在项目开发过程中,界面内容需要根据显示屏幕或缩放比例进行自适应,使用el-table的时候发现height属性使用 calc(100% - 250px) 不起作用,无法进行滚动操作,250是layout页面,其他组件布局高度。

原因

经过调试发现 el-table height 属性 只能使用 数字 或者 字符串 设定值能实现滚动效果。暂时先记录一种处理办法。

解决办法

1. 使用计算属性 窗口大小变化时,动态计算高度

<template>
  <div class="wanan-page-container">
    <el-card ref="cardRef" class="wanan-h-full" body-class="wanan-h-full">
      <el-table
        ref="tableRef"
        :data="tableData"
        show-overflow-tooltip
        :height="table.tableAotoHeight"
        highlight-current-row
        border
      >
        <el-table-column width="40" align="center"></el-table-column>
        <el-table-column prop="Id" label="编码" align="left" />
        <el-table-column prop="Name" label="名称" align="center" />
        <el-table-column prop="Ename" label="代码" align="center" />
      </el-table>
    </el-card>
  </div>
</template>
<script setup lang="ts">
const cardRef = ref();

const table = reactive({
  tableAotoHeight: 550
});
window.onresize = () => {
  nextTick(() => {
    table.tableAotoHeight = cardRef.value?.$el.clientHeight - 250;
  });
};

onMounted(() => {
  table.tableAotoHeight = cardRef.value?.$el.clientHeight - 250;
});
</script>
// 页面最底层容器,95px为菜单栏的高度
.wanan-page-container {
  height: calc(100vh - 95px);
  padding: 10px;  // 统一样式,上下左右都给10px的内边距
}
// 继承父级高度
.wanan-h-full {
  height: 100%;
}
  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值