您现在的位置是:网站首页> 编程资料编程资料
vue中监听scroll事件失效的问题及解决_vue.js_
2023-05-24
400人已围观
简介 vue中监听scroll事件失效的问题及解决_vue.js_
vue监听scroll事件失效问题
vue项目中遇到需要监听页面某个元素距顶部距离实现吸顶效果,正常的window.addEventListener('scroll', this.handleScroll)完全失效,经过一段时间的探索发现这个事件在子组件中会遇到问题。
可以用元素上的 @scroll事件来监听滚动,但有一点要注意,scroll的元素需要确认 设置overflow-y:scroll;height:100%的样式。
下面附实现成功的代码
1.顶部元素添加 @scroll事件监听
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项目中实现描点跳转scrollIntoView的案例_vue.js_
- vue实现前端按钮组件权限管理_vue.js_
- 2022最新前端常见react面试题合集_React_
- JavaScript element的Form表单生成方式_javascript技巧_
- javascript改变this指向的方法汇总_javascript技巧_
- Vite的createServer启动源码解析_vue.js_
- vue如何点击多个tab标签打开关闭多个页面_vue.js_
- Pinia 的 Setup Stores 语法使用实例详解_vue.js_
- JS前端图片最优化压缩方案_javascript技巧_
- Vue3 实现一个自定义toast 小弹窗功能_vue.js_
点击排行
本栏推荐
