Front-end/React

리액트 훅(Hooks)란?

mooyou 2024. 11. 25. 16:05
728x90
300x250
SMALL

리액트 훅(Hooks)은 함수형 컴포넌트에서도 클래스형 컴포넌트 같은 상태 관리와 생명주기등의 로직을 쉽게 사용할 수 있도록 도와주는 기능이다.

Hook은 영어로 갈고리라는 뜻을 갖고 있는데 프로그래밍에서는 원래 있는 어떤 기능에 갈고리를 거는 것 처럼 같이 수행되는기능을 의미하며 훅의 이름은 모두 use로 시작한다.

이전에는 상태관리나 생명주기 관련 기능을 사용하려면 클래스형 컴포넌트를 사용해야 했다.

그러나 리액트 16.8부터 훅이 도입되면서 함수형 컴포넌트에서도 이런 기능을 활용할 수 있게 되었다.

 

훅을 사용하는 이유

1. 간결한 코드

  • 클래스형 컴포넌트의 복잡한 구조(생성자, 메서드 바인딩 등)을 피할 수 있다.
  • 함수형 컴포넌트에서 상태와 로직을 훨씬 직관적으로 관리 할 수 있다.

2. 재사용성 증가

  • 훅을 사용하면 상태 관리와 로직을 별도의 커스텀 훅으로 추출해서 재사용할 수 있다.

3. 직관적인 생명주기 관리

  • 클래스형 컴포넌트는 생명주기 메서드(componentDidMount, componentDidUpdate, componentWillUnmount)가 따로 나뉘어 있지만, 훅에서는 useEffect 하나로 통합적으로 관리할 수 있다.

 

주요 훅 소개

  • useState(상태 관리) :  컴포넌트에서 상태값을 선언하고 관리할 때 사용
  • useEffect(부수 효과 관리) : API호출, DOM 조작, 이벤트 등록 같은 부수적인 작업(side effects)을 처리할 때 사용
  • useRef(DOM 접근 및 참조값 저장) : 컴포넌트의 특정 DOM 요소에 접근하거나 값이 렌더링 간 변경되지 않도록 참조값을 저장할 때 사용
  • useContext(전역 상태 관리) : 컴포넌트 계측 구저가 깊을 때, props를 일일이 전달하지 않고도 데이터를 공유할 수 있다.

 

 

 

728x90
반응형
LIST