国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

VUE中setTimeout和setInterval自動銷毀案例

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

在Vue的大型單頁應用中,在某個路由下,經常會出現需要延遲執行(setTimeout)或者間隔之心(setInterval)的函數,但是每次在頁面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;}

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

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

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

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

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

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

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

data (){ return{ clearTime: ’’ }},mounted () { randomGet () { // 在 1分鐘到 2分鐘之間 不定時執行 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自動銷毀案例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 99久久香蕉| cao草棚视频网址成人 | 欧美一区2区 | 男人使劲躁女人视频小v | 精品老司机在线视频香蕉 | 午夜在线播放免费人成无 | 成人三级在线观看 | 日本黄色大片在线播放视频免费观看 | 日本a级三级三级三级久久 日本a级特黄三级三级三级 | 一区二区三区精品国产欧美 | 日韩三级在线观看视频 | 欧美日韩国产在线人成dvd | 日本免费视频观看在线播放 | 国产美女作爱视频 | 一级毛片在线免费视频 | 美美女下面被cao爽 美女131爽爽爽做爰中文视频 | 欧美高清亚洲欧美一区h | 99久久国产综合精品成人影院 | 国产精品日本欧美一区二区 | 成年人在线免费网站 | 99热.com| 免费播放巨茎人妖不卡片 | 美日韩一区二区 | 国产亚洲免费观看 | 孕妇孕交视频 | 亚洲成av人片在线观看 | 99久久精品免费看国产 | 国产精品成人在线 | 欧美大胆一级视频 | 国产图片亚洲精品一区 | 欧美精品一区二区在线观看 | 国产精品拍拍拍福利在线观看 | 在线观看亚洲专区 | 韩国欧洲一级毛片 | 欧美黄区 | 欧美另类视频一区二区三区 | 最刺激黄a大片免费网站 | 自拍三级| 日本特黄特色高清免费视频 | 真实国产精品视频国产网 | 国产成人精品日本亚洲网址 |