定义:不断地去调用同一个接口。当离开这个界面时,就停止对这个接口的不断调用。
使用说明: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)来取消未执行的超时调用