vue定时器中间变颜色(Vue如何优雅的清除定时器)
类别:编程学习 浏览量:2386
时间:2021-10-13 00:32:58 vue定时器中间变颜色
Vue如何优雅的清除定时器目录
- 前言
- 优化
- 衍生问题:beforeDestroy 没有触发?
清除定时器,相信有相当一部分人是这么写的:
export default { data() { reurn { timer: null } }, mounted() { this.timer = setInterval(() => { console.log('setInterval') }, 2000) }, beforeDestroy() { clearInterval(this.timer) } }
这是一段常见的代码,至少我身边的好几个小伙伴(1-3年经验的都有)都是这么写的,这里存在3个不优雅的问题:
- clearInterval 后没有清空 timer 为 null。
- 开启定时器和清除定时器的代码分散开在两个地方,有损可读性/维护性,用尤大大的话说,这使得我们比较难于程序化地清理我们建立的东西。
- timer 被定义在 data 里,实际上 timer 不需要什么响应式操作,定义在 data 里是没必要的,反而造成性能浪费。
直接上代码:
export default { data() { reurn { } }, mounted() { let timer = setInterval(() => { console.log('setInterval') }, 2000) this.$once('hook:beforeDestroy', () => { clearInterval(timer) timer = null }) } }
这里使用 hook 监听 beforeDestroy 生命周期,这样 timer 只需被定义在生命周期里,以上的问题就全部解决了。
在后台系统中,我们常常会设置页面缓存,而当路由被 keep-alive 缓存时是不走 beforeDestroy 生命周期的,所以有些小伙伴以为在 beforeDestroy 清除定时器就完事了,甚至都没有检查一下,实际上定时器并没有被清除掉。知道了原因也就好解决了,借助 activated 和 deactivated 这两个生钩子:
export default { data() { reurn { } }, mounted() { let timer = setInterval(() => { console.log('setInterval') }, 2000) this.$on('hook:activated', () => { if (timer === null) { // 避免重复开启定时器 timer = setInterval(() => { console.log('setInterval') }, 2000) } }) this.$on('hook:deactivated', () => { clearInterval(timer) timer = null }) } }
这里需要注意一下,由于缓存原因,所以需要用 $on 而不是 $once,不然执行一次后就不会再触发了。
到此这篇关于Vue如何优雅的清除定时器的文章就介绍到这了,更多相关Vue 清除定时器内容请搜索开心学习网以前的文章或继续浏览下面的相关文章希望大家以后多多支持开心学习网!
您可能感兴趣
- vue3 ref 的用法(Vue3中watchEffect的用途浅析)
- vue项目的一些手动配置(使用vue项目配置多个代理的注意点)
- vue十大基础知识(vue实战中的一些实用小魔法汇总)
- vue移动端页面不能上下滑动(vue移动端实现左滑编辑与删除的全过程)
- vuex数据持续化(Vuex数据持久化实现的思路与代码)
- vuevlog制作软件(Vue实现Dialog封装)
- vuecli配置环境变量(Vue CLI中模式与环境变量的深入详解)
- vue3 动态生成组件(如何在vue3.0+中使用tinymce及实现多图上传文件上传公式编辑功能)
- vue怎么实现拖动(Vue拖动截图功能的简单实现方法)
- vue组件滚动加载教程(Vue组件封装上传图片和视频的示例代码)
- vue组件keep-alive的原理是什么(如何理解Vue简单状态管理之store模式)
- vue图片组件使用方法(Vue图片裁剪组件实例代码)
- vue3 props用法(vue3组合API中setup、 ref、reactive的使用大全)
- vue中的指令及用法(详解Vue进阶构造属性)
- vue 网页打印(vue打印功能实现的两种方法总结)
- vue动态生成的下拉框如何获取值(Vue 级联下拉框的设计与实现)
- 三杨 共辅四朝帝王,构建明帝国内阁行政圈(三杨共辅四朝帝王)
- 红色文化进国企(红色文化进国企)
- 车友的选择| 轮毂该如何选(车友的选择轮毂该如何选)
- 秦海璐炫耀和王新军热恋蜜事,不料对方吐槽她吃饱后肚子撅老高(秦海璐炫耀和王新军热恋蜜事)
- 秦海璐一袭旗袍惹人倾心,将高级与淡雅展现的游刃有余(秦海璐一袭旗袍惹人倾心)
- 门外之见 海蛎子味 的表演,能走多远(门外之见海蛎子味)
热门推荐
- thinkphp标签详解(thinkphp整合系列之极验滑动验证码geetest功能)
- php查询数据库给变量赋值(详解PHP变量传值赋值和引用赋值变量销毁)
- .NET中常用的异常类
- linuxsvn服务怎么打开(CentOS SVN服务器如何管理多个项目)
- python3配置教程(python3中property使用方法详解)
- sqlserver函数条件判断(Sql Server 开窗函数Over的使用实例详解)
- python标准库操作键盘(Python中捕获键盘的方式详解)
- mvc renderpartial
- vue 为什么要使用key(详解vue中v-for的key唯一性)
- python中dict怎么创建(Python数据类型之Dict字典实例详解)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9