불리언 토글 로직을 재사용 가능한 커스텀 훅 useToggle로 추출하세요.
function useToggle(initial?: boolean): readonly [
boolean,
() => void,
(next: boolean) => void
];
반환 튜플 순서: [on, toggle, setOn]
function Demo() {
const [on, toggle] = useToggle(false);
return <button onClick={toggle}>{on ? 'on' : 'off'}</button>;
}
useState + useCallback으로 안정적인 함수 참조 유지 (선택)as const)import { useState } from 'react'; export function useToggle(initial: boolean = false) { // TODO: useState로 on 상태를 만드세요 // TODO: toggle은 on을 반전시키는 함수 // TODO: setOn은 직접 boolean을 받는 setter // 반환 순서: [on, toggle, setOn] return [false, () => {}, (_: boolean) => {}] as const; }
Tests