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)
}
}以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
vue使用vue-video-player插件播放视频的步骤讲解
在最近的项目中有一个视频播放的功能,在之前的项目中没有接触过类似的功能,第一次接触,把具体操作步骤一下,这篇文章主要给大家介绍了关于vue使用vue-video-player插件播放视频的相关资料,需要的朋友可以参考下2022-12-12


最新评论