vue3 setup語法糖下的定時器的使用與銷毀
vue3 setup語法糖下的定時器的使用與銷毀
如果在組件中需要使用定時器,注意在銷毀組件的時候,要對定時器進(jìn)行銷毀,否則時間長了會導(dǎo)致頁面卡頓。
<script setup> onMounted(() => { let timer = null; //每5s刷新數(shù)據(jù) timer = setInterval(() => { getAmount(); }, 5000); }) onBeforeUnmount(() => { clearInterval(timer) timer = null; }) </script>
補充:
Vue3 setup語法糖銷毀一個或多個定時器(setTimeout或setInterval)
背景
如果在頁面/組件增加了定時器,就算跳轉(zhuǎn)到其他頁面,定時器也不會被清理,這時候就需要手動清理,不然會有意想不到的bug,也會影響性能。
提示
setTimeout是只執(zhí)行一次,setInterval是循環(huán)執(zhí)行,以下是用setTimeout舉例子,如果想要用setInterval,替換一次方法就行。
- setTimeout替換成setInterval
- clearTimeout替換成clearInterval
銷毀一個定時器
<script setup> import {onMounted, onUnmounted} from "vue"; //注意哈,這里是個空 const timer = ref() //先創(chuàng)建一個定時器 onMounted(() => { timer.value=setTimeout(() => { // do something }, 1500) }) //在頁面銷毀之前先銷毀定時器 onUnmounted(() => { clearTimeout(timer.value) timer.value="" })
銷毀多個定時器
<script setup> import {onMounted, onUnmounted} from "vue"; //注意哈,是個數(shù)組,不是對象,當(dāng)然用對象的方式也行 const timer = ref([]) //先創(chuàng)建數(shù)個定時器 onMounted(() => { timer.value.push(setTimeout(() => { // do something }, 1500)) timer.value.push(setTimeout(() => { // do something }, 1800)) }) //在頁面銷毀之前先銷毀定時器 onUnmounted(() => { for (const timerElement of timer.value) { clearTimeout(timerElement) } timer.value=[] })
到此這篇關(guān)于vue3 setup語法糖下的定時器的使用與銷毀的文章就介紹到這了,更多相關(guān)vue3 setup語法糖內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue實現(xiàn)html轉(zhuǎn)化pdf并復(fù)制文字
這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)html轉(zhuǎn)化pdf的兩種方式,分別為能復(fù)制文字和不能復(fù)制文字的方法,有需要的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-10-10vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決
這篇文章主要介紹了vue+el使用this.$confirm,不能阻斷代碼往下執(zhí)行的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09vue手寫<RouterLink/>組件實現(xiàn)demo詳解
這篇文章主要為大家介紹了vue手寫<RouterLink/>組件實現(xiàn)demo詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06vue element-ui里的table中表頭與表格出現(xiàn)錯位的解決
這篇文章主要介紹了vue element-ui里的table中表頭與表格出現(xiàn)錯位的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08npm無法加載文件:因為在此系統(tǒng)上禁止運行腳本的解決辦法
這篇文章主要介紹了npm無法加載文件:因為在此系統(tǒng)上禁止運行腳本問題的解決辦法,文中通過代碼以及圖文介紹的非常詳細(xì),需要的朋友可以參考下2025-01-01在vue項目中promise解決回調(diào)地獄和并發(fā)請求的問題
這篇文章主要介紹了在vue項目中promise解決回調(diào)地獄和并發(fā)請求的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-11-11vue 打包后的文件部署到express服務(wù)器上的方法
vue是目前最流行的前端框架,今天要介紹的是如何利用vue+webpack+express的方式進(jìn)行前后端分離的開發(fā),下面通過本文給大家分享vue 打包后的文件部署到express服務(wù)器上的方法,感興趣的朋友一起看看吧2017-08-08