解决vue 给window添加和移除resize事件遇到的坑
网络编程 2021-07-04 14:06www.168986.cn编程入门
这篇文章主要介绍了解决vue 给window添加和移除resize事件遇到的坑,具有很好的参考价值,希望对大家有所帮助。一起跟随长沙网络推广过来看看吧
在vue项目中需要监听window窗口变化来时时计算图片的高度,于是就加了一个监听事件;确实监听到了,在离开当前页面进入其他页面改变窗口大小时发现window还是处于监听状态,即移除监听事件并没有生效。
//之前的写法,这样写移除监听事件无效 mounted(){ window.addEventListener('resize',()=>{ '改变窗口大小时需要做的处理' }); }, beforeDestroy() { window.removeEventListener("resize"); }
后来查找相关资料后发现用狼蚁网站SEO优化这种写法可以移除监听
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 的问题
以上这篇解决vue 给window添加和移除resize事件遇到的坑就是长沙网络推广分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程