Categories
Hook10Debounces a value by a specified delay.
Contributed by @itsbrunodev
import { useState, useEffect } from "react";
function useDebouncedValue(value: string, delay: number) {
const [debouncedValue, setDebouncedValue] = useState(value);
useEffect(() => {
const handler = setTimeout(() => {
setDebouncedValue(value);
}, delay);
return () => {
clearTimeout(handler);
};
}, [value, delay]);
return debouncedValue;
}
const [query, setQuery] = useState("");
const debouncedQuery = useDebouncedValue(query, 500);