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

使用Vue封裝一個可隨時暫停啟動無需擔心副作用的定時器

 更新時間:2024年11月13日 11:54:18   作者:yulamz  
這篇文章主要為大家詳細介紹了如何使用Vue封裝一個可隨時暫停啟動無需擔心副作用的定時器,感興趣的小伙伴可以跟隨小編一起學習一下

現(xiàn)成輪子:VueUse 庫的 useIntervalFn 方法

是什么?

創(chuàng)建定時器的組合式函數

為什么要用它?

定時執(zhí)行回調(入參;回調函數、時間間隔、配置項)

控制定時器的行為(返回:開始、暫停定時器的方法)

響應式間隔(入參的時間間隔可以是一個 響應式引用ref 或者一個函數,當它的值改變,定時器會自動更新其間隔時間,無需手動重啟定時器)

立即執(zhí)行選項(入參 options.immediate 控制 是否在初始化時立即啟動定時器;入參 options.immediateCallback 控制是否在調用resume方法猴立即執(zhí)行一次回調函數)

怎么用?

官網有說怎么安裝依賴,就不過多解釋:https://vueuse.org/shared/useIntervalFn/

分析源碼 & 自己手寫一個

源碼

https://github1s.com/vueuse/vueuse/blob/main/packages/shared/useIntervalFn/index.ts

自己手寫

安裝vue-demi依賴后,就可以開始手寫啦~

import type { ComputedRef, Ref, ShallowRef, WritableComputedRef } from 'vue-demi'
import { getCurrentScope, isRef, onScopeDispose, ref, unref, watch } from 'vue-demi'

/**
 * Void函數
 */
export type Fn = () => void

/**
 * 任意函數
 */
export type AnyFn = (...args: any[]) => any

/**
 * 它可能是一個 ref 對象,或者一個普通的值
 */
export type MaybeRef<T = any> =
| T
| Ref<T>
| ShallowRef<T>
| WritableComputedRef<T>

/**
 * 它可能是一個 ref 對象,或者一個普通的值,或者一個 getter 函數
 * @param cb 
 * @param interval 
 */
export type MaybeRefOrGetter<T = any> = MaybeRef<T> | ComputedRef<T> | (() => T)

/**
 * 獲取值、ref 或 getter 的實際值
 */
export function toValue<T>(r: MaybeRefOrGetter<T>): T {
  return typeof r === 'function' ? (r as AnyFn)() : unref(r)
}

/***
 * 是否為客戶端
 */
export const isClient = typeof window !== 'undefined' && typeof document !== 'undefined'

/**
 * 是否處于一個 Vue 3 的響應式 effect 生命周期的作用域內。如果是的話,它會注冊一個清理函數(fn 參數),該函數會在作用域結束時執(zhí)行;如果不是在這樣的作用域內,那么它將不做任何操作。
 * @param fn 
 */
export function tryOnScopeDispose(fn: Fn) {
  if (getCurrentScope()) {
    onScopeDispose(fn)
    return true
  }
  return false
}


export interface UseIntervalOptions {
  /**
   * 立即執(zhí)行這個定時器
   */
  immediate?: boolean
  /**
   * 在調用 resume 函數后,立即執(zhí)行回調函數
   */
  immediateCallback?: boolean
}

export interface Pausable {
  /**
   * 一個 ref 表示 pausable 實例是否處于活動狀態(tài)
   */
  isActive: Readonly<Ref<boolean>>
  /**
   * 暫停定時器
   */
  pause: Fn
  /**
   * 恢復定時器
   */
  resume: Fn
}

export function useIntervalFn(cb: Fn, interval: MaybeRefOrGetter<number> = 1000, options: UseIntervalOptions = {}): Pausable {
  const {
    immediate = true,
    immediateCallback = true
  } = options

  let timer: ReturnType<typeof setInterval> | null = null
  const isActive = ref(false)

  function clean() {
    if (timer) {
      clearInterval(timer)
      timer = null
    }
  }

  function pause() {
    isActive.value = false
    clean()
  }

  function resume() {
    const intervalValue = toValue(interval)
    if (intervalValue <= 0) {
      return
    }
    isActive.value = true

    if (immediateCallback){
      cb()
    }

    clean()

    if (isActive.value) {
      timer = setInterval(cb, intervalValue)
    }
  }

  
  if (immediate && isClient) {
    resume()
  }

  if (isRef(interval) || typeof interval === 'function') {
    const stopWatch = watch(interval, () => {
      if (isActive.value && isClient) {
        resume()
      }
    })
    tryOnScopeDispose(stopWatch)
  }

  tryOnScopeDispose(pause)

  return {
    isActive,
    pause,
    resume
  }
}

到此這篇關于使用Vue封裝一個可隨時暫停啟動無需擔心副作用的定時器的文章就介紹到這了,更多相關Vue封裝定時器內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • vue項目中的遇錯:Invalid?Host?header問題

    vue項目中的遇錯:Invalid?Host?header問題

    這篇文章主要介紹了vue項目中的遇錯:Invalid?Host?header問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • vue拖拽添加的簡單實現(xiàn)

    vue拖拽添加的簡單實現(xiàn)

    本文主要介紹了vue拖拽添加的簡單實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • vue?mixins代碼復用的項目實踐

    vue?mixins代碼復用的項目實踐

    本文主要介紹了vue?mixins代碼復用的項目實踐,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • vue搜索高亮popsearch組件的實現(xiàn)示例

    vue搜索高亮popsearch組件的實現(xiàn)示例

    有時候給頁面內容添加一個關鍵詞搜索功能,如果搜索結果能夠像瀏覽器搜索一樣高亮顯示,那找起來就會很明顯體驗會好很多,本文就來介紹一下vue搜索高亮popsearch組件的實現(xiàn)示例,感興趣的可以了解一下
    2023-09-09
  • Vue兩個版本的區(qū)別和使用方法(更深層次了解)

    Vue兩個版本的區(qū)別和使用方法(更深層次了解)

    在我們使用 vue時,我們可以引用兩個不同版本的 Vue,分別是 Vue完整版(vue.js)和 Vue(vue.runtime.js )非完整版,那么它們的區(qū)別是什么呢,今天我們就來分析下這兩個不同版本之間的區(qū)別,一起看看吧
    2020-02-02
  • Vue中axios攔截器如何單獨配置token

    Vue中axios攔截器如何單獨配置token

    這篇文章主要介紹了Vue axios攔截器如何單獨配置token及vue axios攔截器的使用,需要的朋友可以參考下
    2019-12-12
  • vue數組動態(tài)刷新失敗問題及解決

    vue數組動態(tài)刷新失敗問題及解決

    這篇文章主要介紹了vue數組動態(tài)刷新失敗問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue使用webPack打包發(fā)布后頁面顯示空白的解決

    vue使用webPack打包發(fā)布后頁面顯示空白的解決

    這篇文章主要介紹了vue使用webPack打包發(fā)布后頁面顯示空白的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • 在vue中嵌入外部網站的實現(xiàn)

    在vue中嵌入外部網站的實現(xiàn)

    這篇文章主要介紹了在vue中嵌入外部網站的實現(xiàn)方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11
  • vue3 Element Plus中icon圖標不顯示的解決方案

    vue3 Element Plus中icon圖標不顯示的解決方案

    這篇文章主要介紹了vue3 Element Plus中icon圖標不顯示的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03

最新評論