当前位置:网站首页>设置el-table自动向下滑动(不多解释,直接代码实现)

设置el-table自动向下滑动(不多解释,直接代码实现)

2022-08-04 05:40:00 观山.

//data中添加变量
	refreshTime: 5,
    rollTime: 5,
    rollPx: 1,
//给表格属性添加事件

			<el-table :data="PT_tableData" border height="390" ref="rw_table" @mouseenter.native="mouseEnter" @mouseleave.native="mouseLeave" style="width: 90%; margin: auto">
              <el-table-column prop="name" :label="translateTitle('displayConcepts.columns.指标名称')" width="180" />
              <el-table-column prop="current_value" :label="translateTitle('displayConcepts.columns.当前值')" width="100" />
              <el-table-column prop="warning_value" :label="translateTitle('displayConcepts.columns.报警上下限')" />
            </el-table>
//给表格设置的事件添加在methods

	mouseEnter(time) {
    
        // 鼠标进入停止滚动和切换的定时任务
        this.autoRoll(true)
	},
	// 鼠标离开
      mouseLeave() {
    
        // 开启
        this.autoRoll()
      },
//自动滑动的事件
autoRoll(stop) {
    
        if (stop) {
    
          clearInterval(rolltimer)
          return
        }
        // 拿到表格挂载后的真实DOM
        const table = this.$refs.rw_table
        // 拿到表格中承载数据的div元素
        const divData = table.bodyWrapper
        //0下滑,1上滑
        let sign = 1
        // 拿到元素后,对元素进行定时增加距离顶部距离,实现滚动效果
        rolltimer = setInterval(() => {
    
          // 元素自增距离顶部像素
          divData.scrollTop += sign
          if (Math.ceil(divData.clientHeight + divData.scrollTop) == divData.scrollHeight) {
    
            // 重置table距离顶部距离
            sign = -1
          } else if (divData.scrollTop == 0) {
    
            sign = 1
          }
        }, this.rollTime * 10)
      },
在数据加载完之后执行自动滚动的事件
mounted() {
  this.autoRoll()
},
原网站

版权声明
本文为[观山.]所创,转载请带上原文链接,感谢
https://blog.csdn.net/weixin_47733727/article/details/126039381