亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Vue3 setup語法糖銷毀一個(gè)或多個(gè)定時(shí)器(setTimeout/setInterval)

 更新時(shí)間:2023年10月20日 11:42:58   作者:web小奶精  
這篇文章主要給大家介紹了關(guān)于Vue3 setup語法糖銷毀一個(gè)或多個(gè)定時(shí)器(setTimeout/setInterval)的相關(guān)資料,vue是單頁面應(yīng)用,路由切換后,定時(shí)器并不會自動關(guān)閉,需要手動清除,當(dāng)頁面被銷毀時(shí),清除定時(shí)器即可,需要的朋友可以參考下

背景

如果在頁面/組件增加了定時(shí)器,就算跳轉(zhuǎn)到其他頁面,定時(shí)器也不會被清理,這時(shí)候就需要手動清理,不然會有意想不到的bug,也會影響性能。

提示

setTimeout是只執(zhí)行一次,setInterval是循環(huán)執(zhí)行,以下是用setTimeout舉例子,如果想要用setInterval,替換一次方法就行。

  • setTimeout替換成setInterval
  • clearTimeout替換成clearInterval

銷毀一個(gè)定時(shí)器

<script setup>
import {onMounted, onUnmounted} from "vue";

//注意哈,這里是個(gè)空
const timer = ref()

//先創(chuàng)建一個(gè)定時(shí)器
onMounted(() => {
  timer.value=setTimeout(() => {
    // do something
  }, 1500)
})

//在頁面銷毀之前先銷毀定時(shí)器
onUnmounted(() => {
  clearTimeout(timer.value)
  timer.value=""
})

銷毀多個(gè)定時(shí)器

<script setup>
import {onMounted, onUnmounted} from "vue";

//注意哈,是個(gè)數(shù)組,不是對象,當(dāng)然用對象的方式也行
const timer = ref([])

//先創(chuàng)建數(shù)個(gè)定時(shí)器
onMounted(() => {
  timer.value.push(setTimeout(() => {
    // do something
  }, 1500))
  timer.value.push(setTimeout(() => {
    // do something
  }, 1800))
})

//在頁面銷毀之前先銷毀定時(shí)器
onUnmounted(() => {
  for (const timerElement of timer.value) {
    clearTimeout(timerElement)
  }
  timer.value=[]
})

補(bǔ)充:要想setTimeout指向正確的值,可以使用如下方法:

1、使用箭頭函數(shù)

export default {
 methods: {
  start: function () {
   setTimeout(() => {
    this.end()//娃娃消失
   }, 4000);
  }
 }
}

此時(shí)函數(shù)的this指向的是定義它的時(shí)候的對象,也就是this指向了data內(nèi)中對應(yīng)的變量。

總結(jié) 

到此這篇關(guān)于Vue3 setup語法糖銷毀一個(gè)或多個(gè)定時(shí)器(setTimeout/setInterval)的文章就介紹到這了,更多相關(guān)Vue3 setup語法糖銷毀定時(shí)器內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue+elementUI實(shí)現(xiàn)表單和圖片上傳及驗(yàn)證功能示例

    vue+elementUI實(shí)現(xiàn)表單和圖片上傳及驗(yàn)證功能示例

    這篇文章主要介紹了vue+elementUI實(shí)現(xiàn)表單和圖片上傳及驗(yàn)證功能,結(jié)合實(shí)例形式分析了vue+elementUI表單相關(guān)操作技巧,需要的朋友可以參考下
    2019-05-05
  • vue學(xué)習(xí)筆記之指令v-text && v-html && v-bind詳解

    vue學(xué)習(xí)筆記之指令v-text && v-html && v-bind詳解

    這篇文章主要介紹了vue學(xué)習(xí)筆記之指令v-text && v-html && v-bind詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • Vue使用pdfobject實(shí)現(xiàn)預(yù)覽pdf的示例詳解

    Vue使用pdfobject實(shí)現(xiàn)預(yù)覽pdf的示例詳解

    PDFObject?是一個(gè)?JavaScript?庫用來在HTML中動態(tài)嵌入?PDF?文檔。這篇文章主要為大家詳細(xì)介紹了使用pdfobject實(shí)現(xiàn)預(yù)覽pdf的功能,需要的可以了解一下
    2023-03-03
  • Vue+SpringBoot實(shí)現(xiàn)支付寶沙箱支付的示例代碼

    Vue+SpringBoot實(shí)現(xiàn)支付寶沙箱支付的示例代碼

    本文主要介紹了Vue+SpringBoot實(shí)現(xiàn)支付寶沙箱支付的示例代碼,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-06-06
  • 淺談Vuejs Prop基本用法

    淺談Vuejs Prop基本用法

    本篇文章主要介紹了Vuejs Prop基本用法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-08-08
  • Vue3中無法為el-tree-select設(shè)置反選問題解析

    Vue3中無法為el-tree-select設(shè)置反選問題解析

    這篇文章主要介紹了Vue3中無法為el-tree-select設(shè)置反選問題分析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • vue 組件中slot插口的具體用法

    vue 組件中slot插口的具體用法

    這篇文章主要介紹了vue 中slot 的具體用法,包括子組件父組件的代碼介紹,需要的朋友可以參考下
    2018-04-04
  • vue代理和跨域問題的解決

    vue代理和跨域問題的解決

    這篇文章主要介紹了vue代理和跨域問題的解決,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-07-07
  • vue原生input輸入框原理剖析

    vue原生input輸入框原理剖析

    這篇文章主要為大家介紹了vue原生input輸入框原理剖析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • create?vite?實(shí)例源碼解析

    create?vite?實(shí)例源碼解析

    這篇文章主要為大家介紹了create?vite?實(shí)例源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-11-11

最新評論