定义:不断地去调用同一个接口。当离开这个界面时,就停止对这个接口的不断调用。
使用说明:setInterval不会清除定时器队列,每重复执行1次都会导致定时器叠加,会出现网页卡死现象。但是setTimeout是自带清除定时器的,两者结合使用将避免页面卡死。页面初始化,待开始轮询后,离开页面,通过生命周期destroyed钩子函数,销毁定时任务。
mounted(){
// 轮循
this.timer = window.setInterval(() => {
setTimeout(() => {
console.log('轮询')
},0)
}, 3000);
}vue 是单页面应用,路由切换后,定时器并不会自动关闭,需要手动清除,当页面被销毁时,清除定时器即可。
destroyed(){
clearInterval(this.timer)
},setTimeout,setInterval的介绍以及区别
1、setTimeout():延时任务。在指定的毫秒数后调用函数或计算表达式,
2、setInterval():定时任务。在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。
3、setTimeout()只执行一次,而setInterval可以多次调用。
setInterval() 定时器
//创建
this.timer = setInterval( ()=> {
console.log( "每隔1秒钟显示" )
},1000);//清除定时器 clearInterval(this.timer)
setTimeout() 延时器
var timer = setTimeout( function() {
alert("hellow world!");
},1000);clearTimeout( timer ); //clearTimeout(ID)来取消未执行的超时调用