frontend: useInterval hook

This commit is contained in:
ycdesu 2022-06-15 11:33:21 +08:00
parent b2ba0a86d8
commit 276319c1f3

View File

@ -0,0 +1,20 @@
import {useEffect, useRef} from "react";
export default function useInterval(cb: Function, delayMs: number | null) {
const savedCallback = useRef<Function>();
useEffect(() => {
savedCallback.current = cb
}, [cb])
useEffect(() => {
function tick() {
savedCallback.current();
}
if (delayMs !== null) {
let timerId = setInterval(tick, delayMs)
return () => clearInterval(timerId)
}
}, [delayMs])
}