返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue中监听scroll事件失效的问题及解决
  • 744
分享到

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

2024-04-02 19:04:59 744人浏览 泡泡鱼
摘要

目录Vue监听scroll事件失效问题下面附实现成功的代码vue监听scroll事件vue监听scroll事件失效问题 vue项目中遇到需要监听页面某个元素距顶部距离实现吸顶效果,正

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来获取子元素的顶部距离进行判断 

vue监听scroll事件

很小的功能,记录一下

mounted() {
    window.addEventListener('scroll', this.handleScroll, true)
},
methods: {
    handleScroll: function() {
          console.log(document.documentElement.scrollTop || document.body.scrollTop)
    }
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。 

--结束END--

本文标题: vue中监听scroll事件失效的问题及解决

本文链接: https://lsjlt.com/news/167681.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作