el-table高度自适应、数据查询后高度展示错误问题

在很多场景中我们需要实现表格的高度自适应,即不同屏幕大小下需要使用不同的高度来设置表格,那么我们应该如何实现呢?

1.el-table实现高度自适应

通过以下代码可以实现表格根据屏幕进行自适应

设置表格的高度
<el-table ref="tableData"
:data="tableData" border
:data-key="'id'"
:height="tableHeight"
:max-height="tableHeight">
</el-table>

<script>
export default {
  data: function () {
    return {
     
      tableData: [], // 表格数据
      tableHeight:0, // 表格高度
    };
  },
  mounted() {
    //挂载window.onresize事件(动态设置table高度)
    let _this = this;
    window.onresize = () => {
      if (_this.resizeFlag) {
        clearTimeout(_this.resizeFlag);
      }
      _this.resizeFlag = setTimeout(() => {
        _this.getTableHeight();
        _this.resizeFlag = null;
      }, 100);
    };
  },
  created() {
    this.getTableHeight();
  },
  methods: {
    getTableHeight() {
      let tableH = 200; //距离页面下方的高度
      let tableHeightDetil = window.innerHeight - tableH;
      if (tableHeightDetil <= 300) {
        this.tableHeight = 300;
      } else {
        this.tableHeight = window.innerHeight - tableH;
      }
      console.log(this.tableHeight)
    },
  }
}

2.自适应的问题,数据变化后高度未更新

     当我们自定义高度后,在查询数据时会出现以下的情况,我们表格高度不会撑满到我们实际给定的高度,如下图所示:

 那么我们该如何修改呢?其实很简单,在你的查询方法里面添加如下代码即可:

this.$nextTick(() => {
    this.$refs.tableData.doLayout();
});
注意:要在el-table表里面加ref的指向名称

现在我们在查询,高度也不会出现错误啦!如下图:

`el-table`是Element UI库中的一个表格组件,它支持高度自适应。为了使其高度自适应,你可以通过以下几种方式: 1. **动态高度**:当数据量变化时,可以设置表格的高度为`height`属性为`auto`或`calc(100% - [顶部边距 + 底部边距])`,这样表格会根据其内容自动调整高度。 ```html <el-table :data="tableData" style="height: auto;"> <!-- ... --> </el-table> ``` 2. **响应式设计**:如果你的表格容器有固定的最小高度或最大高度限制,可以结合CSS媒体查询来设置不同的高度样式。例如,在小屏幕设备上,可以设置一个较小的行高,而在大屏幕设备上则设置更高的空间。 ```css .el-table { /* 在小屏下 */ @media (max-width: 768px) { height: 400px; } /* 在大屏下 */ @media (min-width: 769px) { height: 500px; } } ``` 3. **使用V-model绑定外部元素高度**:将表格的高度作为Vue实例的属性,并通过`v-model`与外部元素(如`.vue`文件中的某个div或其他元素)关联,这样当外部元素的大小改变时,表格高度也会相应更新。 ```html <div ref="tableWrapper" v-bind:style="{ height: tableHeight }"></div> <el-table :data="tableData" :height="tableHeight"> <!-- ... --> </el-table> <script> export default { data() { return { tableHeight: 'auto' }; }, computed: { // ... }, watch: { // 当外部元素高度变化时,更新tableHeight $refs.tableWrapper: { handler(height) { this.tableHeight = height; }, deep: true, }, }, }; </script> ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值