vue项目轮询 || setInterval()和setTimeout()区别


定义

  1. setTimeout():延时任务。在指定的毫秒数后调用函数或计算表达式,
  2. setInterval():定时任务。在每隔指定的毫秒数循环调用函数或表达式,直到clearInterval把它清除。
  3. setTimeout()只执行一次,而setInterval可以多次调用。

栗子

  1. setInterval() 定时器
this.timer = setInterval( ()=> {
	console.log( "每隔1秒钟我就会显示一次" ) 
},1000);

    
    
   
   
   
   
  
  
  • 1
  • 2
  • 3
clearInterval(this.timer) //清除定时器

    
    
   
   
   
   
  
  
  • 1
  1. setTimeout() 延时器
var timer = setTimeout( function() {
    alert("hellow world!");      
},1000);

    
    
   
   
   
   
  
  
  • 1
  • 2
  • 3
clearTimeout( timer ); //clearTimeout(ID)来取消 未执行 的超时调用

    
    
   
   
   
   
  
  
  • 1

轮询

轮询就是不断地去调用同一个接口。当离开这个界面时,就停止对这个接口的不断调用。

 mounted(){
	// 轮循
	this.timer = window.setInterval(() => {
		setTimeout(() => {
		   	this.getList() //调用接口的方法
		  	console.log(1111111111)
		 }, 1)
	}, 3000);
  },

    
    
   
   
   
   
  
  
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9

vue 是单页面应用,路由切换后,定时器并不会自动关闭,需要手动清除,当页面被销毁时,清除定时器即可。

destroyed(){
	clearInterval(this.timer)
},

    
    
   
   
   
   
  
  
  • 1
  • 2
  • 3


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM