일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
- 라우팅
- react
- CI/CD
- Preview
- imagePreview
- 접근 제한 라우팅
- routing
- previousState
- S3
- 채팅방
- useEffect
- 배포
- 미리보기
- Redux
- 후기
- FileReader
- 동기
- 항해99
- rendering
- qwe
- 개발
- 스파르타코딩클럽
- Github Actions
- updater
- 비동기
- setstate
- 브라우저 렌더링
- route
- 7기
- socket.io
- Today
- Total
삐옹
리액트 기초편(1) useEffect [❓] 본문
주의
이 글을 함수형 컴포넌트 + react hook API를 기반으로 작성했습니다.
HOOK
class형 컴포넌트로 작성하지 않고 state와 다른 react기능들을 사용할 수 있게 해주는 기능.
State
: 상태값이 저장된 변수
useState
: state 변수와 state 변수를 변경하는 함수를 반환
Side effect(effect)
: 화면이 렌더링 된 이후에 처리되어야 하는 부수적인 것들. 예) API 호출
: 요청 즉시 1차 렌더링 함으로써 UX 측면에서 좋다
종류
정리가 필요한 것
정리가 필요하지 않은 것(network request, DOM 수동조작, 로깅 등)
useEffect
useEffect의 기본 형태입니다.
useEffect(() => {
// 여기에 렌더링 이후 실행할 effect(함수)를 적습니다
return () => {
// 여기에 unmount나 unsubscribe 코드를 적습니다
}
}, [props명, state명, ...]) // 의존성 배열(dependencies array) = deps
- deps : 변경을 감지할 데이터, 혹은 빈배열을 넣습니다.
하는 일?
: 컴포넌트를 렌더링 할 때 우리가 넘긴 함수(‘effect’라고 부릅니다)를 기억했다가, 렌더링이 일어난 후에 어떤 일을 해야하는지 말합니다.
다시 말해 DOM이 업데이트를 수행한 이후에 함수를 불러냅니다. 렌더링 후 effect 호출 (+clean up + deps)
컴포넌트 안에서 쓰는 이유는 뭔가요?
: 컴포넌트 안에 둠으로써 state 값에 함수(effect)가 접근 할 수 있습니다. 최신 state값을 바로 얻을 수 있습니다.
함수(컴포넌트가 함수형으로 만들어져있으니 당연한 말입니다) 안에 있기 때문에 자바스크립트(혹은 브라우저)가 가지고 있는 API를 사용할 수 있습니다.
렌더링 이후 매번 실행이 되나요?
: 기본적으로 첫 번째 렌더링과 이후의 모든 업데이트에서 실행됩니다. react는 effect가 수행되는 시점은 이미 DOM이 업데이트되었음을 보장합니다.
1. 처음 렌더링 됬을 때
state값이 변경되거나 어떤 식으로든 re-rendering이 일어날 때마다 실행됩니다.
useEffect(()=> {
console.log("나타났을때만 호출")
},)
만약 처음 렌더링되고 딱 한 번만 실행시키고 싶다면 deps 위치에 빈배열을 넣습니다.
useEffect(()=> {
console.log("나타났을때만 호출")
},[])
2. 컴포넌트가 re-rendering 될 때(<= 특정 state, props가 바뀔 때)
useEffect(()=> {
console.log("나타났을때만 호출")
},[props(바뀌는값)])
3. 컴포넌트가 DOM에서 제거될 때
useEffect(()=> {
console.log("나타났을때만 호출")
return console.log("클린업 함수")
},)
4. 렌더링 이후 effect 실행 + cleanup 코드예시
import React, { useState, useEffect } from 'react';
function FriendStatus(props) {
const [isOnline, setIsOnline] = useState(null);
useEffect(() => {
function handleStatusChange(status) {
setIsOnline(status.isOnline);
}
ChatAPI.subscribeToFriendStatus(props.friend.id, handleStatusChange);
// effect 이후에 어떻게 정리(clean-up)할 것인지 표시합니다.
return function cleanup() {
ChatAPI.unsubscribeFromFriendStatus(props.friend.id, handleStatusChange);
};
});
if (isOnline === null) {
return 'Loading...';
}
return isOnline ? 'Online' : 'Offline';
}
Clean-up
effect에 정리가 필요한 경우 return 안에 정리를 위한 함수를 넣어서 반환할 수 있다. 정리가 필요 없을 땐 아무것도 반환하지 않습니다.
요약
- useeffect = side effect (+clean up)
- effect에 정리가 필요한 경우 return 안에 정리를 위한 함수를 넣어서 반환할 수 있다. 정리가 필요 없을 땐 아무것도 반환하지 않습니다.
참고
React Hook 공식문서
https://ko.reactjs.org/docs/hooks-effect.html
side effect
https://velog.io/@yes3427/React-Side-Effect
use effect
https://velog.io/@jmean12/useEffect%EB%9E%80
state와 re-rendering
'React' 카테고리의 다른 글
프론트에서 안전하게 로그인 요청하기(feat. 리액트) (0) | 2022.06.19 |
---|---|
state 불변성을 지켜라(댓글 달기) (0) | 2022.06.16 |
Redux + Firebase 게시글 화면에 뿌려주기(실패ver.) (0) | 2022.06.10 |
SPA와 MPA (0) | 2022.05.23 |
Ref와 DOM (0) | 2022.05.23 |