我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue如何监听页面的滚动的开始和结束

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue如何监听页面的滚动的开始和结束

监听页面的滚动的开始和结束

export default {
        data() {
            return {
                oldScrollTop: 0, //记录上一次滚动结束后的滚动距离
                scrollTop: 0 // 记录当前的滚动距离
            }
        },
        watch: {
            scrollTop(newValue, oldValue) {
                setTimeout(() => {
                    if(newValue == window.scrollY) { //延时执行后当newValue等于window.scrollY,代表滚动结束
                        console.log('滚动结束');
                        this.oldScrollTop = newValue; //每次滚动结束后都要给oldScrollTop赋值
                    };
                }, 20); //必须使用延时器,否则每次newValue和window.scrollY都相等,无法判断,20ms刚好大于watch的侦听周期,故延时20ms
                if(this.oldScrollTop == oldValue) { //每次滚动开始时oldScrollTop与oldValue相等
                    console.log('滚动开始');
                }
            }
        },
        methods: {
            handleScroll() {
                window.addEventListener('scroll', () => {
                    this.scrollTop = window.scrollY;
                })
            }
        },
        mounted() {
            this.handleScroll();
        },
        beforeDestroy() {
            window.removeEventListener('scroll'); //离开当前组件别忘记移除事件监听哦
        }
    }

vue监听页面滚动事件

方法:监听滚动实现

通过addEventListener方式监听

通过scroll获取到滚动

export default {
    data () {
        return {
            topNavBg: {
                backgroundColor: ''
              }
        }
    },
    // 滚动监听
    mounted () {
        window.addEventListener('scroll', this.handleScroll) // 监听页面滚动
    },
    methods: {
        // 获取页面滚动距离
        handleScroll () {
            let scrollTop = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop
            console.log(scrollTop, '滚动距离')
        }
    },
    // 滚动重置
        beforeDestroy () {
              window.removeEventListener('scroll', this.handleScroll)
        },
}

问题:监听不到页面的滚动

现象:上述方法不可用,handleScroll只触发一次,且scrollTop为0

原因:html,body的height设置有问题,因为限制了根元素高度,故而无法监听到滚动

// oldCode: 原代码css中
body,html {
  width: 100%;
  height: 100vh; /或者 height: 100%
}
// newCode:新代码改为
body,html {
  width: 100%;
  min-height: 100vh; /或者 min-height: 100% ; 不需要也可以去除
}

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue如何监听页面的滚动的开始和结束

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

如何使用vue监听页面中某个div的滚动事件并判断滚动位置

这篇文章主要介绍如何使用vue监听页面中某个div的滚动事件并判断滚动位置,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 在开发中常常会遇到这样一个vue页面,页面分为左右两部分,左边是目录树,右边是一个类名为xq
2023-06-29

编程热搜

目录