Back To SnippetsuseDebounceDebounce value changes.use-debounce.tsuse-debounce.tsCopy codeimport { useEffect, useState } from 'react'; export default function useDebounce<T>(value: T, delay = 500) { const [debouncedValue, setDebouncedValue] = useState(value); useEffect(() => { const timer = setTimeout(() => { setDebouncedValue(value); }, delay); return () => { clearTimeout(timer); }; }, [value, delay]); return debouncedValue; }