解决element-ui中的el-table中列更新问题以及滚动条会重置到最顶部的问题

本文介绍了在Vue.js中如何在el-table组件完成渲染后动态更新列数据,通过设置key属性和使用Math.random()实现数据刷新。同时,针对更新数据导致滚动条重置到顶部的问题,提供了一种解决方案:记录滚动条高度,在更新key后恢复原高度,确保滚动位置不变。详细方法包括在refreshTable方法中保存并还原滚动条高度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

  1. 当table渲染完成后需要动态更新列的数据时候,此时在el-table属性增加key就可以,例如:
    1. <el-table ref="table" :key="key"

                增加data属性 key,最后需要重新刷新的方法里加上 this.key = Math.random() 就可以

           

      2.问题2,调用 this.key = Math.random()后会导致table的滚动条被重置到最上面的问题,解决办法就是,调用this.key之前先记录滚动条高度,调用完成后还原成之前的高度

        

完美解决方法

/**
     * 刷新table,防止滚动条跑到最上面
    */
refreshTable() {
      const beforeScrollTop = this.$refs.table.$el.querySelector('div.el-table__body-wrapper').scrollTop
      this.key = Math.random()
      setTimeout(() => {
        this.$refs.table.$el.querySelector('div.el-table__body-wrapper').scrollTop = beforeScrollTop
      }, 0)
    },

在需要刷新的地方调用 this.refreshTable(),就可以了

评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值