• 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

  • 相关阅读:
    Gulp使用入门操作---压缩JS
    Linux如何查看进程及如何杀死进程
    连不上GitHub,也ping不通,亲测解决方案
    idea一键生成mybatis工具
    idea逆向生成hibernate工程
    idea常用快捷键大全
    mysql日期函数
    数据库事务
    idea激活码
    oracle创建表前校验是否存在
  • 原文地址:https://www.cnblogs.com/zmyxixihaha/p/12420776.html
Copyright © 2020-2023  润新知