1. table渲染完成需要动态更新列的数据时候,此时在eltable属性增加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(),就可以

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注