欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue定時器清除不掉,導(dǎo)致功能頻繁執(zhí)行問題

 更新時間:2023年06月30日 08:39:13   作者:Dreams゜  
這篇文章主要介紹了vue定時器清除不掉,導(dǎo)致功能頻繁執(zhí)行問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue定時器清除不掉,導(dǎo)致功能頻繁執(zhí)行

前端Vue項目中定時器清除問題

方法1:

常規(guī)使用和清除

clearInterval(this.timer)//使用前先清空定時器
this.timer = setInterval(()=>{
? ? console.log(1)
}, 1000)

方法2:

使用數(shù)組存儲每一個定時器的標識,避免某些原因?qū)е露〞r器未能清除 (如:頁面重復(fù)初始化)

if(!window.timer){ window.timer = []}
// 將存起來的定時器一并清除
window.timer.map(item=>{
? ? clearInterval(item)
})
const timerId = setInterval(()=>{
? ? console.log(1)
}, 1000)
window.timer.push(timerId)

vue中使用定時器(setInterval、setTimeout)

js中定時器有兩種,一個是循環(huán)執(zhí)行 setInterval,另一個是定時執(zhí)行 setTimeout。

注意:定時器需要在頁面銷毀的時候清除掉,不然會一直存在!

1. 循環(huán)執(zhí)行( setInterval )

顧名思義,循環(huán)執(zhí)行就是設(shè)置一個時間間隔,每過一段時間都會循環(huán)執(zhí)行這個方法,直到這個定時器被銷毀掉;

語法:

setInterval(code, milliseconds);
setInterval(function, milliseconds, param1, param2, ...);?
  • code/function 必需。要調(diào)用一個代碼串,也可以是一個函數(shù)。
  • milliseconds 必須。周期性執(zhí)行或調(diào)用 code/function 之間的時間間隔,以毫秒計。
  • param1, param2, ... 可選。 傳給執(zhí)行函數(shù)的其他參數(shù)(IE9 及其更早版本不支持該參數(shù))。  

返回值:      返回一個 ID(數(shù)字),可以將這個ID傳遞給 clearInterval() 來取消執(zhí)行。

eg:

開始的時候創(chuàng)建了一個定時器 setInterval ,時間間隔為2秒,每2秒都會調(diào)用一次函數(shù) valChange,從而使 value 的值+1。

<template>
? <div>
? ? <h1>{{value}}</h1>
? ? <el-button type="primary" @click="start">開始</el-button>
? ? <el-button type="danger" @click="over">結(jié)束</el-button>
? </div>
</template>
<script>
export default {
? data() {
? ? return {
? ? ? timer: "",
? ? ? value: 0,
? ? };
? },
? methods: {
? ? start(){
? ? ? this.timer = setInterval(this.valChange, 2000); // 注意: 第一個參數(shù)為方法名的時候不要加括號;
? ? },
? ? valChange() {
? ? ? this.value++;
? ? ? console.log(this.value);
? ? },
? ? over(){
? ? ? clearInterval(this.timer);
? ? }
? },
? mounted() {},
? beforeDestroy() {
? ? clearInterval(this.timer);
? },
};
</script>

2. 定時執(zhí)行 ( setTimeout)

定時執(zhí)行 setTimeout 是設(shè)置一個時間,等待時間到達的時候只執(zhí)行一次,但是執(zhí)行完以后定時器還在,只是不再運行;

語法:

setTimeout(code, milliseconds, param1, param2, ...)
setTimeout(function, milliseconds, param1, param2, ...)
  • code/function 必需。要調(diào)用一個代碼串,也可以是一個函數(shù)。
  • milliseconds可選。執(zhí)行或調(diào)用 code/function 需要等待的時間,以毫秒計。默認為 0。
  • param1, param2, ...  可選。 傳給執(zhí)行函數(shù)的其他參數(shù)(IE9 及其更早版本不支持該參數(shù))。 

返回值:    返回一個 ID(數(shù)字),可以將這個ID傳遞給 clearTimeout() 來取消執(zhí)行。

eg:

開始時候創(chuàng)建一個定時器 setTimeout,只在2秒后執(zhí)行一次方法。

let timer = setTimeout(() => {
? //需要定時執(zhí)行的代碼
? console.debug("Hello World");
? }, 2000)

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue.js 踩坑記之雙向綁定

    Vue.js 踩坑記之雙向綁定

    這篇文章給大家?guī)砹薞ue.js 踩坑記之雙向綁定問題,非常不錯,具有參考借鑒價值,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧
    2018-05-05
  • vuex?Mutations同步Actions異步原理解析

    vuex?Mutations同步Actions異步原理解析

    這篇文章主要為大家介紹了vuex?Mutations同步Actions異步原理解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • VUE腳手架的下載和配置步驟詳解

    VUE腳手架的下載和配置步驟詳解

    這篇文章主要介紹了VUE腳手架下載和配置,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue3+vite+ts之a(chǎn)xios的坑及解決

    vue3+vite+ts之a(chǎn)xios的坑及解決

    這篇文章主要介紹了vue3+vite+ts之a(chǎn)xios的坑及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • 深入淺析vue全局環(huán)境變量和模式

    深入淺析vue全局環(huán)境變量和模式

    這篇文章主要介紹了vue全局環(huán)境變量和模式的相關(guān)知識,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-04-04
  • vue實現(xiàn)路由鑒權(quán)和不同用戶登錄

    vue實現(xiàn)路由鑒權(quán)和不同用戶登錄

    這篇文章主要為大家詳細介紹了vue中實現(xiàn)路由鑒權(quán)和不同用戶登錄的相關(guān)知識,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2024-04-04
  • Vue3組合式函數(shù)Composable實戰(zhàn)ref和unref使用

    Vue3組合式函數(shù)Composable實戰(zhàn)ref和unref使用

    這篇文章主要為大家介紹了Vue3組合式函數(shù)Composable實戰(zhàn)ref和unref使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-06-06
  • elementUI使用el-upload上傳文件寫法及避坑總結(jié)(上傳圖片/視頻到本地/服務(wù)器及回顯+刪除)

    elementUI使用el-upload上傳文件寫法及避坑總結(jié)(上傳圖片/視頻到本地/服務(wù)器及回顯+刪除)

    upload上傳是前端開發(fā)很常用的一個功能,下面這篇文章主要給大家介紹了關(guān)于elementUI使用el-upload上傳文件寫法及避坑的相關(guān)資料,包括上傳圖片/視頻到本地/服務(wù)器及回顯+刪除,需要的朋友可以參考下
    2023-03-03
  • vue element-ui table表格滾動加載方法

    vue element-ui table表格滾動加載方法

    下面小編就為大家分享一篇vue element-ui table表格滾動加載方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 本地部署element-plus文檔的簡單步驟

    本地部署element-plus文檔的簡單步驟

    由于公司網(wǎng)絡(luò)登element-ui官方文檔很慢,想把他載下來離線文檔本地跑,下面這篇文章主要給大家介紹了關(guān)于本地部署element-plus文檔的簡單步驟,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2023-05-05

最新評論