文档章节

vue中setTimeout切换浏览器页签时怎么清除解决方案

o
 osc_ogi0qclx
发布于 2019/08/23 16:23
字数 293
阅读 15
收藏 0

精选30+云产品,助力企业轻松上云!>>>

大家都知道,vue中有完整的生命周期,this.$router.push('')可以跳到相应的页面中,在beforeDestroy中可以监听到,将定时器清空,又或是通过this._isDestroyed,可以判断出是否还在当前生命周期中,true为不在,false为还在;

今天要说的是在浏览器打开新窗口的情况下将上一页面的定时器清空;

代码如下:

export: {

methods: { 
/***
*定时器刷新接口
* */
  timeRefresh(){
if(this.isLeave) return false;
  //你所需要定时刷新请求的方法OR接口 5秒一刷新
  this.refreshData = window.setTimeout(this.timeRefresh, 5000);
  }
},
mounted() {

  this.timeRefresh();

  let self = this;

//此方法可以监听到浏览器切换页面,也就是离开当前页面时的动态;为了保险起见,建议在beforeDestroy中也清空定时器;

  document.addEventListener('visibilitychange',() => { //浏览器tab标签切换事件

    if(document.visibilityState == 'hidden') { //状态判断 没在当前页面呆着
           self.isLeave = true;
  if(self.refreshData) window.clearTimeout(self.refreshData); self.refreshData = null;
     }else { //回来了
 self.isLeave = false;
      self.refreshData = setTimeout(self.timeRefresh, ((new Date).getTime() % 5000));
 }
});
},
data() {
return {
    isLeave: false,//定义变量判断是否还停留在当前此页面中
    refreshData : null,//定时器定义变量
  }
}

}

o
粉丝 0
博文 500
码字总数 0
作品 0
私信 提问
加载中
请先登录后再评论。
Vue使用过程中常见问题

目录一、vue监听不到state数组/json对象内的元素的值的变化,要手动通知触发 二、vue用splice删除多维数组元素导致视图更新失败情况 三、vue项目如何部署到php或者java环境的服务器? 四、v...

osc_xl828kzf
2018/06/07
2
0
web前端常见面试题(js原生,vue,es6,小程序)合集

VUE 1.什么是 vue 生命周期 2.vue生命周期的作用是什么 3.第一次页面加载会触发哪几个钩子 4.简述每个周期具体适合哪些场景 5.created和mounted的区别 6.vue获取数据在哪个周期函数 7.请详细...

osc_y4l0tx8t
2019/05/13
7
0
vue-element-admin 4.2.0 发布,后台集成方案

vue-element-admin 4.2.0 发布了,vue-element-admin 是一个后台集成解决方案,它基于 vue 和 element。它使用了最新的前端技术栈,内置了 i18 国际化解决方案,动态路由,权限验证,提炼了典...

xplanet
2019/05/22
3.1K
3
Vue优化:常见会导致内存泄漏问题及优化

简介 1 .主要是在单页应用中,用户不会刷新浏览器,所以js应用需要自己清理组件来确保垃圾回收以预期的方式生效 2 . 使用其他第三方可能会创建DOM的插件的时候,在清除DOM的时候一定要保证完...

osc_0ij3yxc4
2019/11/20
6
0
vue 常见坑

1.路由变化页面数据不刷新问题 出现这种情况是因为依赖路由的params参数获取写在created生命周期里面,因为相同路由二次甚至多次加载的关系 没有达到监听,退出页面再进入另一个文章页面并不...

阿豪boy
2018/02/09
26
0

没有更多内容

加载失败,请刷新页面

加载更多

平时使用的Lszrz到底是什么协议?说说Xmodem/Ymodem/Zmodem

XMODEM, YMODEM, and ZMODEM 由于平时使用rz/sz较多,r/s好理解,一个send一个receive。但是由不太清楚z是什么意思,故有此文。 sx/rx, sb/rb (b=batch)和sz/rz分别实现了xmodem,ymodem和z...

独钓渔
53分钟前
17
0
真正的强智能时代已经到来。道翰天琼认知智能机器人平台API大脑。

最近,我常说人工智能的寒冬快要来了,提醒业界要做好思想准备,但同时我也说:冬天来了,春天就不会远了…… 2019年6月我写了篇文章《深度学习的问题究竟在哪?》,说到深度学习的一个主要问...

jackli2020
今天
24
0
什么是控制型人格,控制型人格的筛查测试

一、 什么是控制性人格 拥有控制型人格的人,他们会尽力的隐藏自己的意图,但是又会使用很微妙的方式来利用周围人的弱点,进而占取便宜时,使他们能够得到自己想要的东西。这类人的控制欲非常...

蛤蟆丸子
今天
14
0
【Spring】Spring AOP 代理对象生成逻辑源码分析

1. spring aop案例(POJO注入) 1.0 被代理接口 TargetInterface /** * 被代理的接口 * @author Yang ZhiWei */public interface TargetInterface { void show(); String show......

ZeroneLove
今天
36
0
聊聊dubbo-go的gracefulShutdownFilter

序 本文主要研究一下dubbo-go的gracefulShutdownFilter gracefulShutdownFilter dubbo-go-v1.4.2/filter/filter_impl/graceful_shutdown_filter.go type gracefulShutdownFilter struct {......

go4it
今天
30
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部