为了账号安全,请及时绑定邮箱和手机立即绑定

vue中解绑全局事件

标签:
Vue.js

在vue中,写在methods里面的方法,在页面切换时一般就自动销毁了,但是写在window上的事件,需要我们手动解绑,也是为了提高代码执行效率,案例如下:
1、 当我在新闻资讯页面执行滚动事件时,不断从控制台打印出1


webp

image.png


2、切换到其他页面也会执行滚动事件


webp

image.png

  • 代码如下

 // 滚动侧边栏浮动
  sideFloat() {    // tslint:disable-next-line:no-console
    console.log(1);    const scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
    scrollTop > 410 ? this.isFloat = true : this.isFloat = false;
  }
  mounted() {    window.addEventListener("scroll", this.sideFloat);
  }

解决方案,使用生命周期函数beforeDestroy,在页面离开时执行

 // 对滚动事件绑定及解绑
  beforeDestroy() {    window.removeEventListener("scroll", this.sideFloat);
  }

这样就解决了对全局事件的解绑 +_+



作者:jia林
链接:https://www.jianshu.com/p/bf2bc77e636a


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消