티스토리 뷰
리액트에서 컴포넌트는 생명 주기를 갖습니다.
생명 주기란 컴포넌트가 생성되고 사용되고, 소멸되는 과정을 뜻합니다.
함수 컴포넌트에서 생명 주기는 크게 3가지 단계로 구분할 수 있습니다.
- 렌더 (Render)
- 커밋 (Commit)
- 클린업 (Cleanup)
이 세 단계를 각각 설명하자면 다음과 같습니다.
- 렌더
- 함수 컴포넌트가 호출되어 JSX가 반환됨.
- side effect가 호출되지 않음.
- 커밋
- 실제 DOM에 변화가 적용되는 단계.
- useEffect가 호출되는 단계.
- 클린업
- 컴포넌트가 언마운트되거나, useEffect가 다시 실행되기 전 정리 작업을 수행하는 단계.
- useEffect의 cleanup이 호출되는 단계.
이 단계를 간단히 아래의 코드로 살펴볼 수 있습니다.
import React from 'react';
function Component() {
React.useEffect(() => {
// 커밋 단계: side effect 발생
console.log('Component mounted or updated');
// 클린업 단계: 컴포넌트 언마운트 시 실행
return () => {
console.log('Component unmounted or before update');
};
}, []);
// 렌더 단계: JSX 반환
return <div>Component</div>;
}
'javascript > react' 카테고리의 다른 글
개발 원칙 With SOLID - 2 (0) | 2024.10.16 |
---|---|
개발 원칙 With SOLID - 1 (0) | 2024.10.14 |
useState vs useReducer 어떤걸 써야할까? (0) | 2024.06.24 |
React에서 State와 Props는 어떤 차이가 있을까? (0) | 2024.06.24 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- Google Map
- Apache
- Windows
- 한글
- 팩토리 메소드 패턴
- 구글 맵
- git log
- Windwos
- 한글 깨짐
- 한글깨짐
- 파이썬
- Git
- 플라스크
- 추상 클래스
- 심플 팩토리 패턴
- django
- cmd
- 구글맵
- Python
- ㄹ
- 팩토리 패턴
- 깨짐
- 안드로이드
- 웹
- flask
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
글 보관함