Javascript中的setTimeout方法

为什么要用?

实现延迟执行某些操作,例如延迟更新数据、执行动画

怎么用?

 setTimeout(() => {  
        this.message = 'Hello after 2 seconds!';  
      }, 2000); 

格式

setTimeout(  ()=> {} ,延迟时间(单位ms)   );

还有什么用法?

注意 在上面的例子中,由于我们使用了箭头函数,它不会创建自己的 this 上下文,而是继承父执行上下文中的 this。如果你使用普通函数而不是箭头函数,你需要确保 this 的正确绑定,比如通过 .bind(this)

另外,如果你需要在组件销毁时清除 setTimeout 设置的定时器,以避免内存泄漏,你可以在组件的 beforeDestroy 或 destroyed 生命周期钩子中调用 clearTimeout 函数:

export default {  
  data() {  
    return {  
      timer: null,  
      message: 'Hello Vue!'  
    };  
  },  
  mounted() {  
    this.startTimer();  
  },  
  beforeDestroy() {  
    this.clearTimer();  
  },  
  methods: {  
    startTimer() {  
      // 保存定时器的引用  
      this.timer = setTimeout(() => {  
        this.message = 'Hello after 2 seconds!';  
      }, 2000);  
    },  
    clearTimer() {  
      // 清除定时器  
      clearTimeout(this.timer);  
    }  
  }  
};

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值