溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Vue中使用定時器的方式有哪些

發(fā)布時間:2023-03-17 17:06:37 來源:億速云 閱讀:152 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容主要講解“Vue中使用定時器的方式有哪些”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實用性強。下面就讓小編來帶大家學(xué)習(xí)“Vue中使用定時器的方式有哪些”吧!

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>
    <h2>{{value}}</h2>
    <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 需要等待的時間,以毫秒計。默認(rèn)為 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)

到此,相信大家對“Vue中使用定時器的方式有哪些”有了更深的了解,不妨來實際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進入相關(guān)頻道進行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

vue
AI