Files
ai_web/frontend/src/hooks/useDebouncedValue.ts
2026-01-28 16:00:56 +08:00

15 lines
364 B
TypeScript

import { useEffect, useState } from "react";
export function useDebouncedValue<T>(value: T, delay = 300) {
const [debouncedValue, setDebouncedValue] = useState(value);
useEffect(() => {
const timer = setTimeout(() => {
setDebouncedValue(value);
}, delay);
return () => clearTimeout(timer);
}, [value, delay]);
return debouncedValue;
}