网络编程
位置:首页>> 网络编程>> JavaScript>> 解决vue 给window添加和移除resize事件遇到的坑

解决vue 给window添加和移除resize事件遇到的坑

作者:qq_43561241  发布时间:2024-04-10 13:45:45 

标签: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 里面.并且内部函数体不能使用箭头函数,否则会报 this undefined 的问题

来源:https://blog.csdn.net/qq_43561241/article/details/97393644

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com