ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

当在vue项目中使用滚动监听时,页面跳转后,报错Uncaught TypeError: Cannot read property ‘offsetTop‘ of undefined at VueComp

2022-06-20 12:03:00  阅读:145  来源: 互联网

标签:销毁 跳转 scroll 报错 offsetTop 监听 页面


vue生命周期钩子函数mounted,beforeDestroy

offsetTop of undefined 这个错误,是因为我在mounted页面加载的时,通过addEventListener给window添加了scroll滚动事件。当页面跳转后,没有自动销毁scroll的监听事件,所以会报错,但不影响功能。要避免这样的报错,我们就需要手动在beforeDestroy销毁阶段来销毁这个滚动监听事件就不会报错了。

如下代码:

 mounted() {   //加载阶段创建scroll监听事件
            window.addEventListener("scroll", this.menu);
        },
        beforeDestroy() {    //在加载时添加了scroll监听,如果不销毁,到下一个页面时,没有主动销毁,会报错'offsetTop' of undefined。因此,需要在页面跳转前销毁此监听
            window.removeEventListener("scroll", this.menu)
        },
        methods: {
            //滚动条监听
            menu() {
                let visionTitleOffsetTop = this.$refs.visionTitle.offsetTop;
                let visionTitle = this.$refs.visionTitle.classList;
                ..........
            }
        }

 

 

标签:销毁,跳转,scroll,报错,offsetTop,监听,页面
来源: https://www.cnblogs.com/init-007/p/16392764.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有