Główne logo strony
React

useCallback i debounce w React


Szybki snippet na to, aby połączyć ze sobą useCallback oraz funkcję debounce() (chyba nie muszę nikomu jej przedstawiać 😉) z biblioteki lodash (albo z naszej własnej implementacji).

import { useMemo } from "react";
import debounce from "lodash.debounce";

function MyComponent() {
  const changeHandler = () => {
    // handle the event...
  };
  const eventHandler = () => {
    // handle the event...
  };

  // Option A: useCallback() stores the debounced callback
  const debouncedChangeHandler = useCallback(debounce(changeHandler, 300), []);

  // Option B: useMemo() stores the debounced callback
  const debouncedEventHandler = useMemo(() => debounce(eventHandler, 300), []);

  // ...
}

Sprawdź dokładniejszy opis i więcej przykładów w tym artykule.

Losowy shortKolejny short: React