UNPKG

@e-group/hooks

Version:

eGroup team react-hooks that share across projects.

27 lines (22 loc) 644 B
import { useEffect, useRef } from 'react'; /** * https://overreacted.io/making-setinterval-declarative-with-react-hooks/ */ export default function useInterval(callback, delay) { const savedCallback = useRef(); // Remember the latest callback. useEffect(() => { savedCallback.current = callback; }, [callback]); // Set up the interval. useEffect(() => { function tick() { if (savedCallback && savedCallback.current) { savedCallback.current(); } } if (delay !== null) { const id = setInterval(tick, delay); return () => clearInterval(id); } return () => {}; }, [delay]); }