All files / src/chap07 HookEffect.js

0% Statements 0/13
0% Branches 0/2
0% Functions 0/5
0% Lines 0/11

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32                                                               
import { useEffect, useLayoutEffect, useState } from 'react';
 
// delay 초 동안 처리를 일시 정지하는 sleep 함수 
const sleep = delay => {
  const start = Date.now();
  // 현재 시간이 start(시작 시간)를 초과할 때까지 루프 지속
  while (true) {
   if (Date.now() - start > delay) { break; }
  }
};
 
export default function HookEffect({ init }) {
  const [count, setCount] = useState(0);
 
  // 2000밀리초 후 State(count)를 설정한다.
  useEffect(() => {
  // useLayoutEffect(() => {
    sleep(2000);
    setCount(init);
  }, []);
 
  const handleClick = () => {
    setCount(c => c + 1);
  };
  
  return (
    <>
      <button onClick={handleClick}>카운트</button>
      <p>{count}번 클릭되었습니다.</p>
    </>
  );
}