vue解决el-table表格中表头与内容错位问题

1、问题描述

  • 场景1:当el-table里的内容比较多的时候,table会出现纵向滚动条导致错位。如下图。
  • 场景2:el-table表格列固定左右滑动导致错位。

2、解决方法

直接在请求数据后执行表格自带属性doLayout方法重新加载table,即可解决错位问题。

使用方法如下:

// ElTableHeaderRef是 el-table 标签里添加的 ref="ElTableHeaderRef"
this.$nextTick(() => {
    if (this.$refs.ElTableHeaderRef && this.$refs.ElTableHeaderRef.doLayout) {
        this.$refs.ElTableHeaderRef.doLayout();
    };
});

完整代码如下: 

<el-table ref="ElTableHeaderRef" border  :data="tableData">
    <el-table-column type="index" label="序号" align="center" width="55"></el-table-column>
    <el-table-column  prop="stationname" label="基站名称" show-overflow-tooltip  align="center"></el-table-column>
</el-table>
getTableData() {
            getstationlist(this.searchFrom).then(res => {
                this.tableData = res.rows;
                this.total = res.total;
                this.$nextTick(() => {
                    if (this.$refs.ElTableHeaderRef && this.$refs.ElTableHeaderRef.doLayout) {
                        this.$refs.ElTableHeaderRef.doLayout();
                    };
                });
            }).catch(err => { });
}

3、展示效果

完美解决。

为了在el-table表头使用el-popover,您需要为每个popover绑定一个独特的变量。以下是一个例子,展示了如何在el-table表头使用el-popover: ```html <template> <el-table :data="tableData" style="width: 100%"> <el-table-column prop="date" label="日期" width="180"> <template slot="header"> <div> 日期 <el-popover placement="bottom" width="200" trigger="hover" v-model="popoverVisible1" > <p>这是一个日期选择器</p> <el-date-picker v-model="date" type="date" placeholder="选择日期"></el-date-picker> </el-popover> <el-button slot="reference" icon="el-icon-question" size="mini" @click="popoverVisible1 = true" ></el-button> </div> </template> </el-table-column> <el-table-column prop="name" label="姓名" width="180"> <template slot="header"> <div> 姓名 <el-popover placement="bottom" width="200" trigger="hover" v-model="popoverVisible2" > <p>这是一个输入框</p> <el-input v-model="name" placeholder="请输入姓名"></el-input> </el-popover> <el-button slot="reference" icon="el-icon-question" size="mini" @click="popoverVisible2 = true" ></el-button> </div> </template> </el-table-column> </el-table> </template> <script> export default { data() { return { tableData: [ { date: '2022-01-01', name: '张三' }, { date: '2022-01-02', name: '李四' }, { date: '2022-01-03', name: '王五' } ], popoverVisible1: false, popoverVisible2: false, date: '', name: '' }; } }; </script> ``` 在这个例子,我们为每个el-popover绑定了一个独特的变量(popoverVisible1和popoverVisible2),这样每个popover就可以正常渲染了。同时,我们还为每个popover添加了一个el-button,当用户将鼠标悬停在这个按钮上时,popover就会显示出来。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值