在vue中使用定时器setTimeout、setInterval的心得

最近在做一个数据可视化的项目,其中就不得不考虑数据项定时刷新功能了。
所以就在我们的vue项目中使用了定时器。

1、在vue中,有两套定时器,一套是浏览器API,window对象上的;另一套就是vue/nodejs封装的,需要引入

import { setInterval, clearInterval } from 'timers'

建议使用window对象自带的,因为不容易错。
如果一不小心只引入一个,就怎么也清不掉了。

import { setInterval } from 'timers' // 错误

2、一定要在beforeDestroy中清除定时器。

3、在setTimeout中定义的函数时,奇怪的this对象

mounted () {
	// 第一种,标准调用
	// this指向window对象,因为回调函数是在全局环境下调用的
	window.setTimeout(function () { console.log(this) }, 0)
	
	// 第二种,箭头函数调用
	// 箭头函数在定义时确定this对象的,是vue实例
	window.setTimeout(() => console.log(this), 0)
	
	// 第三种,立即执行函数
	window.setTimeout((function () {
			// this竟然是undefined!不可思议
			// 事实上,this为undefined的情况就只有模块的顶层对象
			// 也就是说,这里的this指向的就是当前vue模块的顶层对象(???)
			console.log(this)
			// this是windo
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值