vue中监听scroll事件失效的问题

vue项目中遇到需要监听页面某个元素距顶部距离实现吸顶效果,正常的window.addEventListener('scroll', this.handleScroll)完全失效,经过一段时间的探索发现这个事件在子组件中会遇到问题。
可以用元素上的 @scroll事件来监听滚动,但有一点要注意,scroll的元素需要确认 设置overflow-y:scroll;height:100%的样式。
下面附实现成功的代码:
1.顶部元素添加 @scroll事件监听

  <div class="specialty-store-page" ref="scrollBox" @scroll="handleBlScroll">

2.确保监听的元素 overflow-y:scroll;height:100%
3.监听事件

   handleBlScroll() {
      let _blTop = this.$refs.bl.getBoundingClientRect().top
      this.tabFixed = _blTop < 46
      this.navShowFlag = this.$refs.scrollBox.scrollTop > this.RootEM * 0.92
      let _gcTop = this.$refs.goodsContainer.getBoundingClientRect().top//这里是子元素距顶部的高度
    }

可以在父元素中添加滚动,通过 this.$refs.goodsContainer.getBoundingClientRect().top来获取子元素的顶部距离进行判断

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值