Vue3通過hooks方式封裝節(jié)流和防抖的代碼詳解
創(chuàng)建 useThrottle Hook
節(jié)流函數(shù)的作用是確保一個(gè)函數(shù)在一段時(shí)間內(nèi)只能被執(zhí)行一次,即使它被連續(xù)調(diào)用多次也只會執(zhí)行一次。
import { ref, onBeforeUnmount } from 'vue';
function useThrottle(callback, delay = 100) {
let timerId = ref(null);
const cancel = () => {
if (timerId.value !== null) {
clearTimeout(timerId.value);
timerId.value = null;
}
};
const throttledCallback = (...args) => {
if (!timerId.value) {
timerId.value = setTimeout(() => {
callback(...args);
timerId.value = null;
}, delay);
}
};
onBeforeUnmount(cancel); // 在組件卸載前清除定時(shí)器
return [throttledCallback, cancel];
}
export default useThrottle;
創(chuàng)建 useDebounce Hook
防抖函數(shù)則是確保在一個(gè)給定的時(shí)間段內(nèi),只有最后一次操作會觸發(fā)函數(shù)執(zhí)行,如果在這段時(shí)間內(nèi)還有新的操作發(fā)生,則重新計(jì)時(shí)。
import { ref, onBeforeUnmount } from 'vue';
function useDebounce(callback, delay = 100) {
let timerId = ref(null);
const cancel = () => {
if (timerId.value !== null) {
clearTimeout(timerId.value);
timerId.value = null;
}
};
const debouncedCallback = (...args) => {
cancel(); // 取消之前的定時(shí)器
timerId.value = setTimeout(() => {
callback(...args);
}, delay);
};
onBeforeUnmount(cancel); // 在組件卸載前清除定時(shí)器
return [debouncedCallback, cancel];
}
export default useDebounce;
解析
- useThrottle: 這個(gè) hook 接受一個(gè)回調(diào)函數(shù)
callback和一個(gè)延遲時(shí)間delay。它返回一個(gè)被節(jié)流的函數(shù)throttledCallback,這個(gè)函數(shù)在首次調(diào)用后會設(shè)置一個(gè)定時(shí)器,在delay時(shí)間之后執(zhí)行callback并重置定時(shí)器。此外,它還返回了一個(gè)cancel函數(shù)用來取消定時(shí)器。 - useDebounce: 類似于
useThrottle,但是它在每次調(diào)用debouncedCallback時(shí)都會先取消任何未完成的定時(shí)器,然后再設(shè)置一個(gè)新的定時(shí)器。這意味著只有在最后一次調(diào)用后的delay時(shí)間結(jié)束后,callback才會被執(zhí)行。
在 Vue 組件中使用這些 hooks
<template>
<div>
<button @click="handleClick">Click me</button>
<p>Clicked at: {{ lastClickTime }}</p>
</div>
</template>
<script>
import useThrottle from './useThrottle';
import useDebounce from './useDebounce';
export default {
setup() {
const lastClickTime = ref('');
const handleAction = () => {
lastClickTime.value = new Date().toISOString();
};
// 使用節(jié)流
const [handleClickThrottled] = useThrottle(handleAction, 500);
// 或者使用防抖
// const [handleClickDebounced] = useDebounce(handleAction, 500);
return {
lastClickTime,
handleClick: handleClickThrottled,
// 或者使用防抖版本
// handleClick: handleClickDebounced,
};
},
};
</script>
這樣,每次點(diǎn)擊按鈕時(shí),節(jié)流或防抖處理函數(shù)就會被調(diào)用,并更新 lastClickTime。你可以根據(jù)需要選擇使用節(jié)流或防抖處理函數(shù)。
以上就是Vue3通過hooks方式封裝節(jié)流和防抖的代碼詳解的詳細(xì)內(nèi)容,更多關(guān)于Vue3 hooks封裝節(jié)流和防抖的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
vue項(xiàng)目中的遇錯(cuò):Invalid?Host?header問題
這篇文章主要介紹了vue項(xiàng)目中的遇錯(cuò):Invalid?Host?header問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-07-07
vue如何實(shí)現(xiàn)多組關(guān)鍵詞對應(yīng)高亮顯示
這篇文章主要介紹了vue如何實(shí)現(xiàn)多組關(guān)鍵詞對應(yīng)高亮顯示問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-10-10
vue-cli或vue項(xiàng)目利用HBuilder打包成移動端app操作
這篇文章主要介紹了vue-cli或vue項(xiàng)目利用HBuilder打包成移動端app操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07
Vue通過Blob對象實(shí)現(xiàn)導(dǎo)出Excel功能示例代碼
這篇文章主要介紹了Vue通過Blob對象實(shí)現(xiàn)導(dǎo)出Excel功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
淺談vuejs實(shí)現(xiàn)數(shù)據(jù)驅(qū)動視圖原理
這篇文章主要介紹了淺談vuejs實(shí)現(xiàn)數(shù)據(jù)驅(qū)動視圖原理,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-02-02

