Custom hook that determines if the component is currently mounted.
import { useEffect, useState } from "react";
import { useIsMounted } from "@tealess/hooks";
const delay = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
function Child() {
const [data, setData] = useState("loading");
const isMounted = useIsMounted();
// simulate an api call and update state
useEffect(() => {
void delay(3000).then(() => {
if (isMounted()) setData("OK");
});
}, [isMounted]);
return <p>{data}</p>;
}
export default function Component() {
const [isVisible, setVisible] = useState < boolean > false;
const toggleVisibility = () => {
setVisible((state) => !state);
};
return (
<>
<button onClick={toggleVisibility}>{isVisible ? "Hide" : "Show"}</button>
{isVisible && <Child />}
</>
);
}