国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

關(guān)于vue中如何清除定時器的方法

這篇具有很好參考價值的文章主要介紹了關(guān)于vue中如何清除定時器的方法。希望對大家有所幫助。如果存在錯誤或未考慮完全的地方,請大家不吝賜教,您也可以點擊"舉報違法"按鈕提交疑問。

一、問題

1、在vue中使用setTimeout定時器的時候,可能會遇到關(guān)不掉的情況,會存在明明已經(jīng)在beforeDestroy和destroyed中設(shè)置了定時器清除了,但是有時候沒生效,定時器還會繼續(xù)執(zhí)行。
2、在這里需要說一下setTimeout的使用場景:
(1)需要執(zhí)行一次定時的時候用得到,比如需要在多久之后執(zhí)行的一次操作
(2)接口需要定時查詢,并且需要在接口返回數(shù)據(jù)后再查詢的情況下(接口定時查詢的時候,該方式會經(jīng)常用得到)

二、問題出現(xiàn)的原因

場景:目前有個接口方法,執(zhí)行該方法需要5s執(zhí)行完成,并且還需要在執(zhí)行完后定時查詢數(shù)據(jù)
問題原因分析:
(1)問題發(fā)生的場景

關(guān)于vue中如何清除定時器的方法文章來源地址http://www.zghlxwxcb.cn/news/detail-408921.html

a. 該方法需要5s執(zhí)行完,但是當(dāng)執(zhí)行到該方法中第2s的時候,切換頁面的時候?qū)⒃摻M件銷毀了
b. 銷毀了該組件,但是該方法還是會在緩存中執(zhí)行往下執(zhí)行,并不會因為組件銷毀而停止執(zhí)行后面的代碼,所以后面的定時器還是會執(zhí)行到,并且后續(xù)的定時器也會一直執(zhí)行
c. 因為一直在緩存中執(zhí)行,并且組件已經(jīng)銷毀了,所以定時器就會存在清不掉的情況
(2)這種情況是偶發(fā)性的,很少有需要執(zhí)行5s的方法,為了將該問題復(fù)現(xiàn)測試,我測試的時候是自己模擬了一下這個場景,所以使用的是5s;大部分的情況可能是幾十毫秒或者幾百毫秒就可以執(zhí)行完成了,但是在銷毀的時候,恰好處于方法執(zhí)行的過程中,就會導(dǎo)致定時器清不掉的情況

三、問題解決思路

1、解決的思路跟我之前寫的關(guān)于定時器的使用及頁面切換時定時器無法清除的問題解決辦法這篇文章差不多,是基于該文章的思路的一個補充,可以一起參考下
2、在使用定時器的組件中,使用一個curPageUrl來記錄當(dāng)前使用組件的頁面所在的路由地址
該參數(shù)是用于對比路由跳轉(zhuǎn)的情況,如果該參數(shù)和當(dāng)前訪問的路由地址不一致,那么就能判斷出使用定時器的組件已經(jīng)銷毀了,不需要再繼續(xù)執(zhí)行了
3、在created或mounted中為curPageUrl賦初始值
this.curPageUrl = this.$route.path;
4、在使用定時器的方法中判斷是否往下執(zhí)行
if (this.curPageUrl && this.curPageUrl != this.$route.path) {
    return false;
}
5、在beforeDestroy和destroyed中為curPageUrl賦一個永遠(yuǎn)不能出現(xiàn)的一個值,并且清除定時器
this.curPageUrl = "end";
this.realtimeLoadPointDataTimer && clearTimeout(this.realtimeLoadPointDataTimer);

四、實現(xiàn)的源代碼

export default {
  data() {
    return {
      curPageUrl: "", // 當(dāng)前頁面的路由地址
    };
  },
  watch: {},
  created() {
    this.query();

    this.curPageUrl = this.$route.path;
  },
  mounted() {},
  beforeDestroy() {
    this.curPageUrl = "end";
    this.realtimeLoadPointDataTimer &&
      clearTimeout(this.realtimeLoadPointDataTimer);
  },
  destroyed() {
    this.realtimeLoadPointDataTimer &&
      clearTimeout(this.realtimeLoadPointDataTimer);
  },
  methods: {
    /** 查詢數(shù)據(jù) */
    query() {
      this.realtimeLoadPointDataTimer &&
        clearTimeout(this.realtimeLoadPointDataTimer);

      if (this.curPageUrl && this.curPageUrl != this.$route.path) {
        return false;
      }

      // 設(shè)置延遲5秒執(zhí)行回調(diào)函數(shù)
      setTimeout(() => {
        if (this.checked == true) {
          // 設(shè)置500毫秒執(zhí)行一次
          this.realtimeLoadPointDataTimer = setTimeout(() => {
            this.query();
          }, 500);
        }
      }, 5000);
    },
  },
};

五、總結(jié)

在開發(fā)過程中,定時器是會經(jīng)常用得到的,這種情況發(fā)生的機率很小,但并不是不會發(fā)生,為了避免該情況發(fā)生,這一個解決方案可能并不是很完美,但是能夠解決這類問題
如果有更好的解決方案,或者使用該解決方案解決類似問題的遇到了問題,歡迎即使交流!!!

到了這里,關(guān)于關(guān)于vue中如何清除定時器的方法的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來自互聯(lián)網(wǎng)用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實不符,請點擊違法舉報進行投訴反饋,一經(jīng)查實,立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費用

相關(guān)文章

  • JavaScript中兩種定時器和清除定時器的使用

    ? 定時器就是在一段特定的時間后執(zhí)行某段程序代碼。 以指定的時間間隔(時間單位為毫秒)調(diào)用一次函數(shù)的定時器。 輪循定時器是以指定的時間間隔(時間單位為毫秒)重復(fù)調(diào)用一個函數(shù)的定時器。 clearTimeout(timeoutID) :清除只執(zhí)行一次的定時器(setTimeout函數(shù))。 timeoutID 為

    2024年02月13日
    瀏覽(22)
  • 定時器的設(shè)置和清除setTimeout、setInterval、setImmediate-NodeJs

    JS是單線程運行邏輯,所有的程序默認(rèn)在一個線程執(zhí)行,出現(xiàn)排隊執(zhí)行。所有的定時器中,回調(diào)函數(shù)會在主線程后事件隊列中執(zhí)行。 ? ? ? ? ? ? ?一次性定時器的 開啟:當(dāng)間隔時間到了,會調(diào)用 一次 回調(diào)函數(shù),間隔時間的單位是毫秒。 ? ? ? ? ? ? ? var timer=setTimeout(回

    2024年02月04日
    瀏覽(17)
  • 關(guān)于JS定時器的整理

    關(guān)于JS定時器的整理

    在JS中定時器有非常大的作用,例如: 執(zhí)行延遲操作:使用setTimeout可以在一定的延遲后執(zhí)行特定的代碼。這對于需要在一定時間后執(zhí)行某些操作的情況非常有用,例如延遲顯示提示信息、執(zhí)行動畫效果等。 定期刷新數(shù)據(jù):使用 setInterval 可以定期執(zhí)行某段代碼,例如定時從服

    2024年02月12日
    瀏覽(13)
  • 關(guān)于單片機的分頻定時器的記錄

    關(guān)于單片機的分頻定時器的記錄

    對于單片機的頻率原來一直不太明白,現(xiàn)在在學(xué)習(xí)進行記錄: 主頻: 分頻 對于分頻來說,實際就是相當(dāng)于間接降低這個主頻,減少這個震蕩次數(shù),比如我分頻系數(shù)為72,那么我就是1S產(chǎn)生的震蕩次數(shù)就是72000000/72=1000000次,相當(dāng)于用少的計數(shù)來對一秒鐘進行計數(shù)。 那么有人好

    2024年04月09日
    瀏覽(24)
  • stm32f407關(guān)于通用定時器各種函數(shù)——PWM(二)

    stm32f407關(guān)于通用定時器各種函數(shù)——PWM(二)

    ????????定時器產(chǎn)生PWM:在計數(shù)器頻率固定時,PWM 頻率由 自動重載寄存器(TIMx_ARR) 的值決定,其占空比由 捕獲/比較寄存器(TIMx_CCRx) 的值決定 ????????定時器工作在遞增計數(shù)模式,縱軸是計數(shù)器的計數(shù)值 CNT,橫軸表示時。當(dāng) CNT=CCRx 時,IO 輸出高電平(邏輯 1);

    2024年02月08日
    瀏覽(15)
  • vue中銷毀定時器

    vue是單頁面應(yīng)用,路由切換后,定時器并不會自動關(guān)閉,需要手動清除,當(dāng)頁面被銷毀時,清除定時器即可。 場景:在A.vue頁面有一個定時a,然后跳轉(zhuǎn)到B.vue頁面,此時A頁面的定時器a依然在運行。 解決方式一: 首先在data里進行定義定時器; 然后在mounted里使用定時器; 最

    2024年02月12日
    瀏覽(22)
  • 關(guān)于STM32的hal庫中滴答定時器uwTick溢出的思考和分析

    思考:如果中斷函數(shù)HAL_IncTick中的uwTick一直增加導(dǎo)致溢出會不會導(dǎo)致延時不準(zhǔn)? 下面展示一些 STM32的官方庫文件stm32f1xx_hal.c部分摘錄 。 系統(tǒng)Tick頻率設(shè)置為1毫秒中斷一次,每1ms產(chǎn)生一次Tick中斷, 在Tick中斷中uwTick++; 那么當(dāng)自增到0xFFFFFFFF后就會溢出,再從0開始自增 。 0xFFFF

    2024年03月21日
    瀏覽(27)
  • jbpm定時器不生效問題梳理

    springboot+struts2+hibernate+mysql+jbpm4 測試環(huán)境可以執(zhí)行定時器 是阿里云 正式環(huán)境不可以執(zhí)行定時器 阿里云 兩個庫不同,代碼相同,推測是表數(shù)據(jù)導(dǎo)致的問題 但是不清楚各表結(jié)構(gòu)及定時任務(wù)的執(zhí)行流程

    2024年02月12日
    瀏覽(16)
  • Vue中 使用定時器 (setInterval、setTimeout)

    js中定時器有兩種,一個是 循環(huán)執(zhí)行 setInterval ,另一個是 定時執(zhí)行 setTimeout 。 注意:定時器需要在頁面銷毀的時候清除掉,不然會一直存在! 1. 循環(huán)執(zhí)行( setInterval ) 顧名思義,循環(huán)執(zhí)行就是設(shè)置一個時間間隔,每過一段時間都會循環(huán)執(zhí)行這個方法,直到這個定時器被銷毀

    2024年02月12日
    瀏覽(15)
  • 在 React 中如何使用定時器

    在React中使用定時器通常有兩種方式:使用 setInterval 和 setTimeout 函數(shù)。 使用 setInterval 函數(shù): 首先,在組件中導(dǎo)入 useEffect 和 useState 函數(shù): 在組件中聲明一個狀態(tài)變量來存儲定時器的ID: 在組件的 useEffect 鉤子函數(shù)中啟動定時器: 在上述代碼中,通過 useEffect 中的一個空數(shù)組

    2024年02月10日
    瀏覽(16)

覺得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包