React Dojo

Buscar

Busca conceptos, ejercicios y quizzes

utility

useDebounce

Retrasa la actualización de un valor hasta que haya pasado cierto tiempo sin cambios. Ideal para inputs de búsqueda y filtros en vivo.


useDebounce.ts
import { useState, useEffect } from "react"

export function useDebounce<T>(value: T, delay: number): T {
  const [debouncedValue, setDebouncedValue] = useState<T>(value)

  useEffect(() => {
    const timer = setTimeout(() => {
      setDebouncedValue(value)
    }, delay)

    return () => clearTimeout(timer)
  }, [value, delay])

  return debouncedValue
}
¿Fue útil?
Inicia sesión para dar feedback