생각/TIL,WIL

[WIL] 2022.10.10 ~ 10.16 라이프 싸이클 차이

kyunghoonk00k 2022. 10. 17. 21:22
반응형

오늘 한 일
axios && redux toolkit 적용해보기
코딩알려주는 누나 강의 듣기 
React 심화 학습 자료

오늘 느낀 것
Redux toolkit 적응하기 
클론코딩 
reducer 파일들은 합쳐서 store로 보내라(combineReducers)
import rootReducer from "./reducers";
// index파일 자동으로 읽어옴

좋았던 점
Redux, React 프로젝트 이해가 되어간다


개선점
확실하게 이해는 안 된다
컴포넌트 쪼개는 방법알아가기
Redux toolkit 적응하기 
미들웨어 사용법 적응하기

내일 할 일
오전 시험
axios && redux toolkit 적용해보기
코딩알려주는 누나 강의 듣기 
React 심화 학습 자료
개발자모드vs프로덕션모드
환경변수 공부하기
https://shinsangeun.github.io/posts/react/react-env



-----



1. 클래스형 컴포넌트와 라이프사이클(Life-cycle)
라이프사이클 이벤트는 컴포넌트의 렌더링과 DOM 이벤트 등을 의도대로 관리할 수 있으며, 이를 통해 성능을 개선할 수 있습니다.

클래스형 컴포넌트의 라이프사이클은 다음과 같이 세 가지로 분류하며, 각 메소드는 자주 사용하거나 유의할 부분만 정리하겠습니다.


마운팅(Mounting) – 컴포넌트가 생성될 때 한 번만 실행(아래 순서대로 실행)
– constructor()

– UNSAFE_componentWillMount() -> version 17부터 공식적으로 권장X

– render()

– componentDidMount()

업데이트(Update) – props 또는 state가 변경될 때마다 실행
– UNSAFE_componentWillReceiveProps() -> 권장X

– UNSAFE_componentWillUpdate() -> 권장X

– render()

– componentDidUpdate(prevProps, prevState, snapshot)

언마운팅(Unmounting) – 컴포넌트가 제거될 때 한 번만 실행
– componentWillUnmount()


위와 같이 각각의 컴포넌트는 [ 마운팅 -> 업데이트(반복) -> 언마운팅 ]의 라이프사이클을 갖습니다.

이전에는 직관적인 이름을 갖는 다양한 메소드(componentWillMount, componentWillReceiveProps, shouldComponentUpdate, componentWillUpdate)를 통해 이벤트 발생 시점마다 세세한 조작이 가능했으나 현재는 버그나 안전성의 이유로 점점 더 단순해지고 있습니다.

위 기능을 모두 대체하는 훅(Hook)이 너무 편해서 클래스형 컴포넌트를 반드시 사용해야 하는 상황이 아니라면 함수형 컴포넌트와 함께 useEffect를 사용하는 방법이 권장되고 있습니다.

2. 함수형 컴포넌트와 useEffect(Hook)
리액트 16.8부터 추가된 훅(Hook)은 클래스를 사용하지 않아도 state 또는 리액트의 여러 기능을 편하게 사용하도록 해주는 기능입니다.

이 중 useEffect 훅은 라이프사이클과 관련이 있는데요.


리액트 공식 문서에서 useEffect를 위와 같이 설명합니다.

즉 componentDidMount, componentDidUpdate, componentWillUnmount를 모두 합쳐 놓은 것과 같은 기능을 하는 것이 useEffect입니다.

모두 합쳐 놓았지만 작성 방법에 따라 각각의 기능을 구현할 수 있습니다.

먼저 함수의 시그니쳐는 다음과 같은 모습이며, 첫 번째는 실행할 함수, 두 번째는 조건을 배열로 전달하며 두 번째 매개변수는 생략이 가능합니다.

useEffect(함수, 배열);

  useEffect(() => {
      console.log('useEffect is working');
  });

– 마운팅만 설정(=componentDidMount)
마운팅 시에만 실행하고 싶은 경우에는 두 번째 매개변수로 빈 배열을 전달하면 됩니다.

function testStatus(props) {
  useEffect(() => {
      console.log('useEffect on mounting');
  },[]);
  return <div>test</div>;
}

– 언마운팅만 설정(=componentWillUnmount)
언마운팅 시에만 실행하고 싶은 경우에는 함수를 리턴하면서 두 번째 매개변수로 빈 배열을 전달하면 됩니다.

function testStatus(props) {
  useEffect(() => {
      
      console.log('useEffect on mounting');
      return () => {
        console.log('useEffect on unmounting');
      }
  },[]);
  return <div>test</div>;
}

– 데이터 업데이트마다 설정(=componentDidUpdate)
useEffect에서 두 번째 매개변수를 전달하지 않으면 렌더링마다 해당 훅이 실행됩니다.

하지만 관련 없는 데이터로 인한 리렌더링에도 훅이 실행되면 의도치 않은 결과를 낳거나 성능의 저하를 불러올 수 있으므로 실행의 기준이 되는 데이터를 지정하고 실행 시점을 설정할 수 있습니다.

이를 위해서는 두 번째 매개변수인 배열에 체크할 데이터를 넣으면 됩니다.

function testEffect(props) {
  useEffect(() => {
      console.log('re-rendering');
  });
  useEffect(() => {     
      console.log('props is changed');
  },[props.data]);
  return <div>test</div>;
}

useEffect를 사용하면서 몇 번의 시행착오만 거치면 원하는 기능을 어느 정도 구현할 수 있습니다.

https://choonse.com/2022/01/13/588/

반응형

'생각 > TIL,WIL' 카테고리의 다른 글

[TIL]2022.10.19  (0) 2022.10.20
[TIL] 2022.10.17  (0) 2022.10.18
[TIL]2022.10.14  (0) 2022.10.15
[TIL]2022.10.13  (0) 2022.10.14
[TIL]2022.10.12  (0) 2022.10.12