亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術(shù)文章
文章詳情頁

VUE中setTimeout和setInterval自動銷毀案例

瀏覽:90日期:2022-11-27 17:45:22

在Vue的大型單頁應用中,在某個路由下,經(jīng)常會出現(xiàn)需要延遲執(zhí)行(setTimeout)或者間隔之心(setInterval)的函數(shù),但是每次在頁面destroy之前,都必須手動清理掉。

正常代碼如下:

beforeDestroy() { this._timer && clearTimeout(this._timer);}

但是如果一不小心,就會忘記,會造成意想不到的情況,那么有什么辦法能避免這種情況嗎?

當然有,那就是重新寫一個setTimeout的方法(或者干脆劫持window.setTimeout)。

var _pageTimer = []; Vue.prototype.setTimeout = (fn, time) => { let handler = window.setTimeout(fn, time); _pageTimer.push(handler); return handler;}

在路由層面,當每次頁面變更時,執(zhí)行清理工作:

router.beforeEach((to, from, next) => { _pageTimer.map(handler => { window.clearTimeout(handler); }) })

再頁面使用時,調(diào)用Vue的setTimeout,這樣是不是方便多了呢? setInterval也是一樣的。

該方法還適用于對于頁面異步請求的ajax處理,可以通過獲取ajax的handler,在切面切換時,調(diào)用handler.abort() 取消請求,避免對服務器資源的不必要的壓力。

補充知識:在vue中使用 setTimeout ,退出頁面后,計時器沒有銷毀

問題:頁面在使用 setTimeout 定時循環(huán)某方法,或者在兩個頁面之間跳轉(zhuǎn)時間小于定時器的時間間隔時,定時器還在運行。

原因:當我們刷新頁面時,會將當前頁面之前創(chuàng)建的 setTimeout 以及其他定時器都清除掉,但是僅僅是路由切換是不會清除的。

data (){ return{ clearTime: ’’ }},mounted () { randomGet () { // 在 1分鐘到 2分鐘之間 不定時執(zhí)行 var r = Math.random() * (2 - 1) + 1 var t = Math.ceil(r * 60000) // console.log(t) this.clearTime = setTimeout(() => { this.submit() this.randomGet() }, t) }, submit () { console.log(’aaaa’) }},destroyed () { clearTimeout(this.clearTime) // 清除}

以上這篇VUE中setTimeout和setInterval自動銷毀案例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持好吧啦網(wǎng)。

標簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 日本一级毛片片免费观看 | 亚洲人精品| 网友自拍区一区二区三区 | 国产精品亚洲精品日韩己满十八小 | 免费三级黄色片 | 第一次男生很猛的进去视频 | 成人亚洲网 | 手机看片久久高清国产日韩 | 国产精品久久一区二区三区 | 精品国产免费观看一区高清 | 九九九九精品视频在线播放 | 色婷婷久久合月综 | 亚洲一区二区三区久久久久 | 国产特黄一级一片免费 | 成年人黄色大片大全 | 亚洲黄色免费网址 | 国内一级野外a一级毛片 | 日韩一区二区三区四区 | 一级黄色在线视频 | 黄色片在线免费 | 免费黄色视屏网站 | 欧美激情成人网 | 成人免费在线网站 | a在线观看免费网址大全 | 亚洲综合欧美 | 欧美日韩一区二区在线观看 | 成人精品一区久久久久 | 久久看视频 | www在线小视频免费 www在线观看免费视频 | 国产成人啪精品午夜在线观看 | a国产成人免费视频 | 精品国产免费第一区二区 | 人人做天天爱夜夜爽中字 | 欧美 日韩 国产 成人 在线观看 | 天天色踪合合 | 麻豆激情 | 九九老司机在线视频精品 | 精品久久久久久国产免费了 | 亚洲一区国产 | jyzzjyzz国产免费观看 | 91影院在线观看 |