Vue中在组件销毁时清除定时器(setInterval)

在mounted中创建并执行定时器,然后在beforeDestroy或者destroyed中清除定时器

    <template>
      <div class="about">
      </div>
    </template>
    <script>
    export default {
        name: "about",
        data() {
            return {
                //接收定时器
                timer: ""
            };
        },
        mounted() {
            let _this = this;
            let num = 0;
            //创建并执行定时器
            this.timer = setInterval(() => {
              //当num等于100时清除定时器
                if (num == 100) {
                    clearInterval(_this.timer);
                }
                console.log(num++);
            }, 1000);
        },
        beforeDestroy() {
            //清除定时器
            clearInterval(this.timer);
            console.log("beforeDestroy");
        },
        destroyed() {
            //清除定时器
            //clearInterval(this.timer);
            console.log("destroyed");
        }
    };
    </script>
    <style scoped>
    </style>

这样在组件销毁时会清除定时器,具体参考的是vue的生命周期函数,详情去官网查看哦

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • vue笔记 一.vue实例 vue的生命周期 beforeCreate(创建前), created(创建后), b...
    秋殇1002阅读 1,068评论 0 1
  • 基于Vue的组件库 https://github.com/ElemeFE/element" element 饿了...
    _执着执着再执着阅读 32,767评论 4 230
  • 这次匆忙补作业,我认为也符合牌的提示。 第一眼看到这两张牌,我高兴了一下,好丰盛呀。我的问题承接了第一次问题,想继...
    太阳岩阅读 1,428评论 0 1
  • 我很羡慕会聊天的人,真的。 有次朋友聚会,认识不认识的,一群人,围在饭店的圆桌前。席间,有组织者逐一介绍大家认识。...
    言几又阅读 269评论 0 2