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
- 자바스크립트
- nodejs
- 알고리즘
- js
- git
- 백준
- 컴퓨터공학
- 패스트캠퍼스
- CS
- 야놀자
- LinkSnap
- CSS
- 국비지원
- 부트캠프
- 코딩테스트
- computerscience
- 그리디
- Javascript
- KAKAO
- html/css/js
- 컴퓨터과학
- 국비지원취업
- BFS
- 프론트엔드개발자
- 코테
- 너비우선탐색
- DFS
- 호이스팅
- cpu
- github
Archives
- Today
- Total
My Boundary As Much As I Experienced
useEffect 내에서 eventListener 설정 시 동작하는 원리 본문
오늘 만든 resize 이벤트가 끝나면 0.5초 이후 true값을 반환하는 useCatchResizeEnd 훅.
import { useEffect, useState } from 'react';
export const useCatchResizeEnded = () => {
const [isEnded, setIsEnded] = useState(false);
useEffect(() => {
let resizeTimeout: NodeJS.Timeout;
setIsEnded(false);
const handleResize = () => {
clearTimeout(resizeTimeout);
resizeTimeout = setTimeout(() => {
console.log('timeout이 멈췄습니다.');
setIsEnded(true);
}, 500);
};
window.addEventListener('resize', handleResize);
return () => {
window.removeEventListener('resize', handleResize);
};
}, []);
return [isEnded];
};
useEffect내에 의존성 배열을 비워뒀다.
순간 의존성배열이 없으면 mount될 때 한 번 실행되니
resize이벤트가 계속 발생해도 캐치 못하는게 아닌지 고민했다.
그러나 첫 mount 때 addEventListener를 등록 한 번 하면, 계속 resize를 listening하고있는 상태는 유지된다.
그리고 unmount될 때 클린업 함수가 실행되서 resize 리스너를 제거한다.
오히려 의존성 배열에 어떠한 상태를 넣었는데 그게 계속 업데이트되면
업데이트 될 때마다 useEffect내의 클린업 함수를 실행하고 다시 이벤트 리스너를 재등록하게 되기 때문에,
한 번 이벤트 리스너를 등록해두고 페이지를 이탈하기 전까지 쭈욱 유지하고 싶으면
의존성 배열을 비워두는 것이 좋다.
결과적으로 0.5초 이후 값이 바뀌는 isEnded로 throttle 비슷한 효과를 내며 불필요한 렌더를 방지할수 있다.
'FrontEnd > React' 카테고리의 다른 글
클래스 컴포넌트와 라이프사이클 (0) | 2024.04.13 |
---|---|
내가 MSW를 구현한 방법 (HTTP, HttpResponse) (0) | 2024.03.21 |
Vitest 테스트 라이브러리 구성과 TDD (0) | 2024.01.02 |
(패스트캠퍼스X야놀자 테크 스쿨) 숙박 예약 사이트 '빨리잡아' 구현 (0) | 2023.12.21 |
vite쓸꺼면 Jest는 쓰지말기 (1) | 2023.12.20 |