inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라 먹는 리액트(React.js) : 기초부터 실전까지

10.2) useMemo와 연산 최적화

제가 생각하는 일기 분석 시작이 2번 되는 호출되는 이유가 맞는지 궁금합니다

458

강태민

작성한 질문수 16

0

const getData = async () => {
    const res = await fetch(
      "https://jsonplaceholder.typicode.com/comments"
    ).then((res) => res.json());

    const initData = res.slice(0, 20).map((it) => {
      return {
        author: it.email,
        content: it.body,
        emotion: Math.floor(Math.random() * 5) + 1,
        created_date: new Date().getTime(),
        id: dataId.current++,
      };
    });
    setData(initData);
  };

  useEffect(() => {
    getData();
  }, []);

  const getDiaryAnalysis = useMemo(() => {
    console.log("일기분석");

|

 

처음 App 컴포넌트 실행이 되었을 때 useEffect를 통해 getData는 데이터를 불러오고 있는 상태이고(비동기가 맞을까요?)

getDiaryAnalysis가 실행되면서 처음 "일기분석" 실행되고

getData에서 데이터를 불러 온 상태가 되면 useEffect가 mount되면서 App컴포넌트가 한번 더 실행되는게 맞을까요?

javascript react node.js

답변 1

0

이정환 Winterlood

안녕하세요 이정환입니다.

App컴포넌트는 첫 마운트 때 한번 호출됩니다.
그리고 getData 함수에서 setData를 호출해 상태를 업데이트 했을 때 한번 더 호출됩니다.
따라서 App 컴포넌트(함수)는 총 두번 호출되게 됩니다.

이때 getDiaryAnalysis 함수를 호출하는 코드를 useMemo로 메모이제이션 해주지 않으면 이 함수가 컴포넌트가 리렌더 될 때 마다 즉 호출될 때 마다 계속 다시 실행됩니다.
따라서 useMemo를 이용해 불필요한 재 호출을 방지하는 것 입니다.

  • useEffect가 마운트 되는것은 아닙니다.
    마운트의 주체는 컴포넌트이며 이는 컴포넌트가 처음 화면에 등장한다는 의미입니다.

 

VSCode 설정 문의

0

15

2

PPT 코드 관련 질문

0

13

2

useEffect와 lifecycle문의

0

38

2

프론트엔드 학습 수준 문의

0

51

2

리액트 챕터별 코드에서 eslint 설정파일이 없어요

0

55

2

데이터 로딩중 화면만 계속 나와요!!

0

57

2

퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요

0

85

2

이후의 커리큘럼 문의

0

104

2

실슬환경 설정에서 save후 console.log 부분이 새로고침이 안되는현상입니다.

0

54

2

최적화 관련 질문있습니다 (useMemo 등)

0

86

3

프로바이더 컴포넌트의 위치는 어떤 기준인가요?

1

82

3

Date 객체에 관련하여 질문드립니다.

0

87

2

리액트 개정판 교재 질문

0

60

2

예제코드가 안나와요!

0

79

2

select a variant 선택에서 javascript와 javascript+react compiler 중 무엇을 선택해야하나요? com

0

112

2

onMouseEnter 관련 문의 드립니다

0

93

3

배열의 렌더링 관련 질문 드립니다.

0

74

2

2:40초 refObj를 콘솔로 출력시 오류가 발생합니다.

0

115

2

TS, 리액트 강의중에 뭘 먼저 수강하는게 좋을까요?

0

140

2

useCallback 적용한 onCreate, onUpdate, onDelete 함수..

0

71

1

vs code 자동완성관련 문의

0

121

2

91강 useEffect내에서 상태변화함수 호출시 발생하는 에러

1

187

2

87강 필터 함수 질문

0

71

2

useRef, useState count 비교

0

67

2