vue页面中定时器的使用
我们在使用vue开发项目的时候,或多或少会用到定时器,那么,在vue中使用定时器和我们在平时写js时候使用定时器一样吗,答案肯定是不一样的,定时器有个销毁操作,如何在vue中销毁一个定时器。
答案:在beforeDestroy生命周期销毁定时器。
1、为什么销毁它:
在页面a中写了一个定时器,比如每隔一秒钟打印一次1,当我点击按钮进入页面b的时候,会发现定时器依然在执行,这是非常消耗性能的。
2、解决方案1:
mounted(){ this.timer = setInterval(()=>{ console.log(1) },1000) }, beforeDestory(){ clearInterval(this.timer) }
以上方式有两点不好的地方:
它需要在这个组件实例中保存这个timer,如果可以的话最好只有生命周期钩子可以访问到它。这并不算严重的问题,但是它可以被视为杂物。
我们的建立代码独立于我们的清理代码,这使得我们比较难于程序化的清理我们建立的所有东西。
解决方案2(推荐):通过$onec这个事件侦听器在定义完定时器之后的位置来清除定时器
mounted(){ const timer = setInterval(()=>{ console.log(1) },1000) this.$once('hook:beforeDestroy', ()=>{ clearInterval(timer) }) }
官网参考链接:https://cn.vuejs.org/v2/guide/components-edge-cases.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现