解决vue 给window添加和移除resize事件遇到的坑
在vue项目中需要监听window窗口变化来时时计算图片的高度,于是就加了一个监听事件;确实监听到了,但是在离开当前页面进入其他页面改变窗口大小时发现window还是处于监听状态,即移除监听事件并没有生效。
//之前的写法,这样写移除监听事件无效 mounted(){ window.addEventListener('resize',()=>{ '改变窗口大小时需要做的处理' }); }, beforeDestroy(){ window.removeEventListener("resize"); }
后来查找相关资料后发现用下面这种写法可以移除监听
methods:{ listenResize(){ '窗口大小改变时的操作' } }, mounted(){ window.addEventListener('resize',this.listenResize); }, beforeDestroy(){ window.removeEventListener("resize",this.listenResize); }
补充知识:vue监听屏幕变化&销毁监听事件
记一次小坑.
由于用到echarts需要自适应屏幕,所以在vue中用了监听事件并且考虑到性能问题,所以用lodash库的debounce做了包裹.代码如下:
mounted(){ window.addEventListener('resize',debounce(this.resize,200),true) }, beforeDestroy(){ window.removeEventListener('resize',this.resize,true) }, methods:{ resize(){ this.radarChart.resize() } }
然而发现切换到其他的页面的时候,屏幕改变的时候还是会触发resize事件,因为之前写过类似功能,代码是没有问题的,但是就是会触发,心里也是觉得奇怪,研究了一下,发现addEventListener的方法里面不加debounce就可以了.如下:
mounted(){ window.addEventListener('resize',this.resize,true) }, beforeDestroy(){ window.removeEventListener('resize',this.resize,true) }, methods:{ resize:debounce(function(){ this.radarChart.resize() },300), }
debounce需要加在methods里面.并且内部函数体不能使用箭头函数,否则会报thisundefined的问题
以上这篇解决vue给window添加和移除resize事件遇到的坑就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。