您现在的位置是:网站首页> 编程资料编程资料
vue项目中销毁window.addEventListener事件监听解析_vue.js_
2023-05-24
336人已围观
简介 vue项目中销毁window.addEventListener事件监听解析_vue.js_
销毁window.addEventListener事件监听
今天在做项目的过程中,组件中调用iframe时,由于在组件的created方法中写了监听,用于接收iframe发来的信息,但是在组件销毁的时候并没有去掉监听,导致组件创建几次,监听方法就会执行几次,特此记录
created() { window.addEventListener('message', this.receiveMessage, false) },beforeDestroy() { // 在组件生命周期结束的时候销毁。 window.removeEventListener('message', this.receiveMessage, false) },window.addEventListener监听scroll事件
今天想在vue的项目里面用下拉加载,然后就直接写了:
mounted () { window.addEventListener( 'scroll', this.scrollHander) }, methods: { scrollHander () { } }但是我发现我切换路由以后依旧其他页面也触发了scrollHandler函数,然后我想到使用了vue-router做的spa项目,window对象不变的,所以需要在每次使用后销毁。
解决办法
我回去看了下vue文档的生命周期,看到了destroyed,然后直接在这个周期内销毁就可以了。
mounted () { window.addEventListener('scroll', this.scrollHander) }, destroyed () { window.removeEventListener('scroll', this.scrollHander) }使用throttle出现的新问题
下拉加载一般需要配合throttle限流函数(原理可以看这里)来避免频繁触发,所以优化代码成这样:
mounted () { let _this = this window.addEventListener('scroll', throttle(() => { _this.scrollHander() },200 )) },然后发现没法用removeEventListener了,因为这个函数第二个参数不接受匿名函数。
最后代码
用一个变量中转下
mounted () { let _this = this this.throttleLoad = throttle(() =>{ _this.scrollHander() },200) window.addEventListener('scroll', this.throttleLoad) }, destroyed () { window.removeEventListener('scroll',this.throttleLoad) }, methods: { scrollHander () { } }以上为个人经验,希望能给大家一个参考,也希望大家多多支持。
您可能感兴趣的文章:
相关内容
- 浏览器视频帧操作方法 requestVideoFrameCallback()_javascript技巧_
- element-ui表单提交自动清空隐藏表单值实现_vue.js_
- JavaScript垃圾回收机制(引用计数,标记清除,性能优化)_javascript技巧_
- vue中this.$createElement方法的使用_vue.js_
- vue基础ESLint Prettier配置教程详解_vue.js_
- JavaScript对象与JSON格式的转换及JSON.stringify和JSON.parse的使用方法_javascript技巧_
- vue单选按钮,选中如何改变其当前按钮颜色_vue.js_
- vue data中的return使用方法示例_vue.js_
- 在vue项目中引入scss并使用scss样式详解_vue.js_
- Vue中在setup下如何使用自定义指令_vue.js_
