Blog içindeki snippets
TypeScriptreacthooksperformance

useDebounce Hook

Değeri geciktiren minimal React hook. Input filtreleme ve arama için ideal.

Kod
use-debounce.ts
TypeScript
import { useEffect, useState } from "react";

export function useDebounce<T>(value: T, delayMs = 300): T {
  const [debounced, setDebounced] = useState<T>(value);

  useEffect(() => {
    const timer = setTimeout(() => setDebounced(value), delayMs);
    return () => clearTimeout(timer);
  }, [value, delayMs]);

  return debounced;
}
Kullanım Örneği
usage
TypeScript
const [query, setQuery] = useState("");
const debouncedQuery = useDebounce(query, 400);

// debouncedQuery sadece 400ms sonra güncellenir