Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 괄호제거
- 딥러닝
- LV3
- 큐
- 이분탐색
- 이진탐색
- KeyboardAvoidingView
- 브루트포스
- 자료구조
- 11831
- 골드5
- 복잡도 측정
- TouchableWithoutFeedback
- 실버1
- PYTHON
- FlatList
- 수정렬하기4
- 백준
- 17089
- 그리디
- 2800
- 시간초과해결
- 그래프
- 머신러닝
- ReactNative
- 프로그래머스
- React #새파일생성
- useHeaderHeight
- 상담원 인원
- 3079
Archives
- Today
- Total
지니 코딩일기
React.memo 본문
요약
- 컴포넌트를 React.memo()로 wrapping하면 렌더링될 때 결과를 메모이징(Memoizing)함
- 렌더링될 때 이전 렌더링과 props가 같다면 React는 메모이징(Memoizing)된 내용을 재사용함
- 같은 실행을 반복하지 않게 함으로써 성능 향상을 누릴 수 있음
- 이 메서드는 오직 성능 최적화를 위하여 사용됩니다. 렌더링을 “방지”하기 위하여 사용하지 마세요. 버그를 만들 수 있음!!
예시
const MyComponent = React.memo(function MyComponent(props) {
/* props를 사용하여 렌더링 */
});
설명
- 고차 컴포넌트 (Higher Order Component)
- 컴포넌트가 동일한 props로 동일한 결과를 렌더링해낸다면, React.memo를 호출하고 결과를 메모이징(Memoizing)하도록 래핑하여 경우에 따라 성능 향상 가능
- 마지막으로 렌더링된 결과를 재사용
function MyComponent(props) {
/* props를 사용하여 렌더링 */
}
function areEqual(prevProps, nextProps) {
/*
nextProps가 prevProps와 동일한 값을 가지면 true를 반환하고, 그렇지 않다면 false를 반환
*/
}
export default React.memo(MyComponent, areEqual);
'Programming > 인턴' 카테고리의 다른 글
React Hooks: useRef() (0) | 2022.06.24 |
---|