时间:2021-05-26
一、问题来源。
在项目中,我们经常有这样的需求,一个页面初始化后,需要不断的去请求后端,来获取当前某个记录的最新状态。
显然,这个可以用setTimeout以及回调中继续setTimeout来实现。
我们假设定时器是在页面#/test/aaa上创建的。
但是,会遇到以下两个问题,我从#/test/aaa 这个页面切换到 #/test/bbb页面后如果停留在#/test/bbb,定时器还在跑。
其次,如果我不断在#/test/aaa 和 #/test/bbb两个页面之间不断的切换,而且切换时间小于定时器的间隔时间时,也会出现
重复创建setTimeout的情况。
现在的问题就是,我们如何做到管理定时器。
二、示例代码。
created() { if ( this.timeOut ) { clearTimeout(this.timeOut); } this.getListIng();},computed: { timeOut: { set (val) { this.$store.state.timeout.compileTimeout = val; }, get() { return this.$store.state.timeout.compileTimeout; } },},methods: { getListIng() { // 这里是一个http的异步请求 if ( getUrlModule() == 'aaa' ) { let _this = this; this.timeOut = setTimeout(() => { _this.getListIng(); }, 5000); } else { this.timeOut = ''; } },}(1)如上面代码所示,当创建页面(created执行)时,会先判断变量this.timeOut是否存在,如果存在,先clearTimeout掉。
(2)而,this.timeOut这个变量对应的是全局store里的this.$store.state.timeout.compileTimeout。并且是双向绑定的,这个
请自行搜索vue2.0中computed用法。
(3)在我们的主函数getListIng()中,会先使用函数getUrlModule()根据url判断当前页面是否是aaa页面,如果是的,就执行setTimeOut,
如果不是,就不行执行了,并且设置this.timeOut = '';
我们假设上面没有if ( getUrlModule() == 'aaa' ) 这句判断,会出现,当我们已经跳出了当前aaa页面,去了bbb页面并且一直停留在bbb页面时,
还有setTimeout在执行,就会不断有http的请求。
如果没有if ( this.timeOut ) { clearTimeout(this.timeOut); } 这句代码。当我们不断在2个页面之间切换时,且切换的频率很高。会出现多次创建
setTimeout的情况。这个逻辑稍微有点绕,请阅读者自行演算。
三、我们必须清楚的事实。
(1)vue中$store里创建的变量,其实是全局变量,这个变量在切换页面时不会清除,当我们刷新页面时会清除掉。
(2)在前端页面中,当我们刷新页面时,会将当前页面之前创建的setTimeout以及其他定时器都清除掉。但是,切换页面(仅仅是路由切换)
是不会清除的。
(3)setTimeout、setinterval有本质的不同,前者只执行一次,除非你在回调中,不断的调用,而后者是不间断调用的。但是,我在各种实践中发现,
还是setTimeout好用。因为,setTimeout可以根据条件,及时在回调中停用。如果采用setinterval,我们很有可能捕捉不到停用的条件而无法停用。
补充:Vue之SetTimeout
1.前言
相信很多人都遇到过这样的问题,页面数据需要不断的刷新,也就是不断的发送ajax请求来更新数据,那么在vue中怎样做才比较好呢?这里介绍一下我踩的坑,以及解决方案
2.问题
settimeout用来调用请求数据,但是我遇到的问题就是,没有用合适的方式去关闭settimeout,出现了离开当前页面,请求还在不断的发送问题,这样给服务器带来了无必要的压力。附上之前的代码:
说明:这一段代码是嵌在getDeployList方法中的,离开当前页面的是时候,必须要去手动的把这个settimeout清除才行。一般这个写在destoryed()这个钩子里。
window.clearTimeout(this.deployTimeOutId);虽然这样处理了,但在逻辑比较复杂的情况下,还是出现了没有关闭的情况,而且排查起来很痛苦。下面介绍一种针对Vue比较好的做法。
3.解决方案
let self=this; if (self && !self._isDestroyed) { setTimeout(() => { if (self && !self._isDestroyed) self.getDeployList(); }, 5000); }_isDestroyed这个属性表示的是当前这个组件是否有被销毁,true表示当前的组件已经被销毁,通过上面这个判断,我们就不需要自己手动的去用ID来清除了,这个就相当于递归嘛,有了一个结束判断,避免了死循环咯~~
总结
以上所述是小编给大家介绍的vue项目开发中setTimeout等定时器的管理问题,希望对大家有所帮助,如果大家有任何疑问请
给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在web开发中,我们通常需要使用定时器功能,使用setTimeout和setInterval函数。那么在ReactNative中,是否也提供了定时器的功能呢?答
进入正题,先说说定时器。在javascritp中,有两个关于定时器的专用函数,分别为:1.倒计定时器:timename=setTimeout("function
在javascritp中,有两个关于定时器的专用函数,它们是:1.倒计定时器:timename=setTimeout("function();",delayti
定时器1 用以指定在一段特定的时间后执行某段程序。 setTimeout(): 格式:[定时器对象名=]setTimeout(“”,毫秒) 功能:执行一
在javascritp中,有两个关于定时器的专用函数,分别为:1.倒计定时器:timename=setTimeout("function();",delayti