vue中监听scroll事件失效的问题及解决
iamgeek · 152浏览 · 发布于2022-09-16
这篇文章主要介绍了vue中监听scroll事件失效的问题及解决,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
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) } }
以上为个人经验,希望能给大家一个参考,
相关推荐
RN开发环境的npm私库本地debug调试
manongba · 695浏览 · 2019-05-09 17:03:46
你不知道的浏览器渲染原理
追忆似水年华 · 1370浏览 · 2019-05-09 22:47:56
基于iview的router常用控制方式
追忆似水年华 · 993浏览 · 2019-06-03 10:39:21
编程小知识之 JavaScript 文件读取
manongba · 714浏览 · 2019-06-10 09:16:16
浏览器关闭后,Session会话结束了么?
追忆似水年华 · 903浏览 · 2019-06-13 09:39:50
分类专栏
最新发布
最热排行
0评论