Front-end/React
eslint-plugin-react-hooks 패키지
mooyou
2024. 12. 2. 18:20
728x90
300x250
SMALL
eslint-plugin-react-hooks 패키지는 React의 훅(Hooks) 사용을 올바르게 유지하고 버그를 예방하기 위해 ESLint 규칙을 제공하는 플러그인이다.
이 패키지를 통해 useEffect, useMemo, useCallback등 React훅의 사용에서 발생할 수 있는 일반적인 문제를 잡아낼 수 있다.
주요 기능
1. react-hooks / rules-of-hooks :
- 목적 : 훅 사용 규칙 위반을 방지
- 내용 : React의 훅은 특정 규칙에 따라 사용되어야 한다. 예를 들어, 훅은 함수 컴포넌트나 커스텀 훅에서만 사용할 수 있고, 조건문이나 반복문 안에서 사용해선 안 된다.
예시 오류 :
if (condition) {
useEffect(() => { /* ... */ }); // 오류 발생: 훅이 조건문 안에 사용됨
}
2. react-hooks/exhaustive-deps:
- 목적 : useEffect, useMemo, useCallback의 의존성 배열을 자동으로 검사해서 빠뜨린 의존성을 찾아내는 것
- 내용 : 의존성 배열을 정확히 지정하지 않으면 React가 의도대로 동작하지 않을 수 있다. 예를 들어, useEffect에서 사용된 변수나 함수가 의존성 배열에 빠지면 예기치 않은 결과가 발생할 수 있다.
예시 오류 :
useEffect(() => {
console.log(data); // data를 사용했지만, 의존성 배열에 포함하지 않음
}, []); // 경고 발생: 의존성 배열에 data 추가 필요
사용 방법
eslint-plugin-react-hooks를 사용하려면 ESLint 설정 파일에 플러그인을 추가한다.
{
"plugins": [
"react-hooks"
],
"rules": {
"react-hooks/rules-of-hooks": "error",
"react-hooks/exhaustive-deps": "warn"
}
}
이제 위 규칙에 따라 잘못된 훅 사용이나 빠뜨린 의존성이 있을 경우 ESLint가 오류나 경고를 보여준다.
eslint-plugin-react-hooks는 이러한 규칙을 통해 React훅을 안전하고 일관성 있게 사용할 수 있게 도와준다.
728x90
반응형
LIST