inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

11.1) Context란

객체 재생성에 대한 질문입니다.

366

emJ

작성한 질문수 3

0

안녕하세요

data와 함수들을 같이 전달했을 때 '객체'의 재 생성이 일어나는데, useMemo로 래핑 했음에도 왜 dispatches의 재 생성을 막을 수 없는건가요?

nodejs javascript react

답변 1

0

이정환 Winterlood

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

제가 작성해주신 질문을 제대로 이해했는지 모르겠습니다만...

우선 함수들이 useCallback으로 래핑되어 재 생성되지 않는다고 해도

data는 재 생성되기 때문에 결론적으로 Provider에게 value Prop으로 전달되는 객체 자체는 재 생성됩니다. 따라서 하위 컴포넌트들이 리렌더 됩니다.

이것을 막기 위해서는 재 생성되지 않는 함수들만 따로 모아서 별도의 Context.Provider를 설정해 공급해 주어야 합니다.

0

emJ

안녕하세요!

data와 분리하여 전달했을 때 data 값이 변하면 결국 재생성이 일어나 하위컴포넌트들의 리랜더가 일어난다. 때문에 분리하여 작성한 dispatches의 Provider도 하위 컴포넌트이기 때문에 useMemo로 래핑해준다.

가 맞을까요? 맞다면 결론적으로 분리해주어야 하는 이유에대해서는 이해가 되는데 data와 함수들을 같이 전달되었을 때의 경우는 이해되지 않습니다.

같이 전달하던 따로 전달하던 결국 하위컴포넌트들의 리렌더가 일어나 useMemo를 사용하게 되는데

이 useMemo가 data와 전달하면 작동하지 않는 것인가요?

감사합니다

존재하지 않는 일기 url입력 시 alert이 두 번 떠요

0

35

1

교재(3쇄)와 강의 내용 문의

0

35

2

12.13) 하단 여백 스타일링 관련 질문 드립니다.

0

67

2

에러 질문드립니다

0

64

2

VSCode 설정 문의

0

71

2

PPT 코드 관련 질문

0

49

2

useEffect와 lifecycle문의

0

66

2

프론트엔드 학습 수준 문의

0

82

2

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

0

74

2

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

0

73

2

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

0

104

2

이후의 커리큘럼 문의

0

127

2

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

0

73

2

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

0

104

3

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

1

97

3

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

0

97

2

리액트 개정판 교재 질문

0

76

2

예제코드가 안나와요!

0

86

2

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

0

132

2

onMouseEnter 관련 문의 드립니다

0

111

3

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

0

84

2

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

0

137

2

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

0

153

2

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

0

73

1