【element-ui】el-table横向滚动后,通过is-scrolling-left获取滚动高度失效的问题

el-table横向滚动后,通过is-scrolling-left获取滚动高度失效的问题

需求

现在有一个需求,需要监听el-table的纵向滚动,当滚动高度达到特定值时进行一些操作。

代码如下:

js 复制代码
methods:{
	throttledHandleScroll() {
      // 如果已经有定时器存在,则不执行方法,实现节流
      if (this.throttleTimer || this.paging) return;
      this.throttleTimer = setTimeout(() => {
        this.handleScroll(); // 实际执行滚动逻辑的方法
        this.throttleTimer = null; // 执行完后清空定时器ID,允许下次触发
      }, 100); // 200毫秒的节流时间间隔
    },
	handleScroll() {
      let dom = this.$refs.multipleTable.$el.getElementsByClassName('is-scrolling-left')[0];
      if (dom) {
        // console.log('handleScroll', dom.scrollTop);
        if (dom.scrollTop >= 80) {
          this.hiddenFilter = true;
        }
        if (dom.scrollTop <= 0) {
          this.hiddenFilter = false;
        }
      }
    },
},
mounted() {
    this.$nextTick(() => {
      this.$refs.multipleTable.$el
        .getElementsByClassName('is-scrolling-left')[0]
        .addEventListener('scroll', this.throttledHandleScroll);
    });
  },
beforeDestroy() {
  this.$refs.multipleTable.$el
    .getElementsByClassName('is-scrolling-left')[0]
    .addEventListener('scroll', this.throttledHandleScroll);
},

问题

当el-table横向滚动之后,

js 复制代码
let dom = this.$refs.multipleTable.$el.getElementsByClassName('is-scrolling-left')[0];

会取得一个undefind,也就是说没有找到类名为is-scrolling-left的元素。

原因

随着el-table的横向滚动,is-scrolling-left这个类名会依次变化为is-scrolling-middle,is-scrolling-right

解决

使用el-table__body-wrapper替换is-scrolling-left,el-table__body-wrapper这个类名是永远不会变动的

handleScroll方法中获取dom的一行修改为

相关推荐
社恐的下水道蟑螂3 分钟前
用CSS3拍一部《星球大战》片头?前端导演的"原力"修炼指南
前端·javascript
Juzisuan17 分钟前
深入解析 forEach 与 for...of 在循环体中执行 await 时的区别
javascript
濑户川1 小时前
Vue3 计算属性与监听器:computed、watch、watchEffect 用法解析
前端·javascript·vue.js
前端九哥1 小时前
我删光了项目里的 try-catch,老板:6
前端·vue.js
顽疲1 小时前
SpringBoot + Vue 集成阿里云OSS直传最佳实践
vue.js·spring boot·阿里云
VT.馒头1 小时前
【力扣】2725. 间隔取消
javascript·leetcode·1024程序员节
weixin_409383122 小时前
cocos 用widget将ui组件固定在屏 随着分辨率自适应 编辑器界面canvas作为手机屏参考 将ui组件放进去 deepseek解答
ui·cocos
一 乐2 小时前
车辆管理|校园车辆信息|基于SprinBoot+vue的校园车辆管理系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·车辆管理
百锦再2 小时前
Python、Java与Go:AI大模型时代的语言抉择
java·前端·vue.js·人工智能·python·go·1024程序员节
菩提树下的凡夫2 小时前
前端vue的开发流程
前端·javascript·vue.js