[ReactJS로 영화 웹 서비스 만들기] Effects

2021. 12. 22. 21:24· course/nomadcoder
  • reactjs는 state가 바뀔 때마다 해당 component 전체가 다시 렌더링 됨
    • import { useState } from "react";
      
      function App() {
        const [counter, setValue] = useState(0);
        const onClick = () => setValue((prev) => prev + 1);
        console.log("call an api");
        return (
          <div>
            <h1>{counter}</h1>
            <button onClick={onClick}>click me</button>
          </div>
        );
      }
      console.log("call an api")는 한번만 실행하고 싶어도 state 변화할 때마다 다시 실행
  • component 내의 특정 부분(코드)을 state 변화할 때마다 렌더링되지 않게하기 -> useEffect 함수 사용
    • import { useState, useEffect } from "react";
      
      function App() {
        const [counter, setValue] = useState(0);
        const onClick = () => setValue((prev) => prev + 1);
        // console.log("call an api");
        console.log("i run all the time");
        useEffect(() => {
          console.log("i run only once");
        }, []);
        return (
          <div>
            <h1>{counter}</h1>
            <button onClick={onClick}>click me</button>
          </div>
        );
      }
      export default App;
      console.log("i run only once")는 state가 바뀌어도 다시 렌더링 되지 않음 (최초 한번만 실행)
    •  
    • 첫 번째 인자(함수)에 선택적으로 렌더링 하고 싶은 코드 삽입
    • import { useState, useEffect } from "react";
      
      function App() {
        const [counter, setValue] = useState(0);
        const [keyword, setKeyword] = useState("");
        const onClick = () => setValue((prev) => prev + 1);
        console.log("I run all the time");
        const onChange = (event) => setKeyword(event.target.value);
        useEffect(() => {
          console.log("I run only once.");
        }, []);
        useEffect(() => {
          console.log("I run when 'keyword' changes.");
        }, [keyword]);
        useEffect(() => {
          console.log("I run when 'counter' changes.");
        }, [counter]);
        useEffect(() => {
          console.log("I run when 'keyword' or 'counter' changes");
        }, [keyword, counter]);
        return (
          <div>
            <input
              value={keyword}
              onChange={onChange}
              type="text"
              placeholder="Search here..."
            />
            <h1>{counter}</h1>
            <button onClick={onClick}>click me</button>
          </div>
        );
      }
      export default App;
       
    • useEffect 두번째 인자(리스트)로 어떤 state가 변화하는가에 따라 다시 렌더링할지 여부 설정 가능
  • Cleanup function: component가 삭제되었을때 실행되는 함수 (useEffect 첫번째 인자 return 이후 삽입)
    • import { useState, useEffect } from "react";
      
      function Hello() {
        // useEffect(function () {
        //   console.log("hi :)");
        //   return function () {
        //     console.log("bye :(");
        //   };
        // }, []);
        // Hello 컴포넌트 생성 시 hi, 삭제 시 bye
        useEffect(() => {
          console.log("hi :)");
          return () => console.log("bye :(");
        }, []);
        return <h1>Hello</h1>;
      }
      
      function App() {
        const [showing, setShowing] = useState(false);
        const onClick = () => setShowing((prev) => !prev);
        return (
          <div>
            {showing ? <Hello /> : null}
            <button onClick={onClick}>{showing ? "Hide" : "Show"}</button>
          </div>
        );
      }
      component가 삭제될 때에도 원하는 코드 실행 가능
저작자표시 비영리 변경금지 (새창열림)

'course > nomadcoder' 카테고리의 다른 글

[ReactJS로 영화 웹 서비스 만들기] Create React App  (0) 2021.11.17
[ReactJS로 영화 웹 서비스 만들기] Props  (0) 2021.11.12
[ReactJS로 영화 웹 서비스 만들기] State  (0) 2021.11.11
[ReactJS로 영화 웹 서비스 만들기] Basics of React  (0) 2021.11.09
'course/nomadcoder' 카테고리의 다른 글
  • [ReactJS로 영화 웹 서비스 만들기] Create React App
  • [ReactJS로 영화 웹 서비스 만들기] Props
  • [ReactJS로 영화 웹 서비스 만들기] State
  • [ReactJS로 영화 웹 서비스 만들기] Basics of React
hjkim0502
hjkim0502
개발 일지
hjkim0502
CODELOG
hjkim0502
글쓰기
전체
오늘
어제
  • Codelog (168)
    • course (61)
      • nomadcoder (5)
      • spartacoding (22)
      • inflearn (27)
      • 생활코딩 (7)
    • CS (68)
      • algorithm & data structure (34)
      • OS (26)
      • CA (0)
      • DB (8)
      • Network (0)
    • 코딩테스트 (2)
    • 이노베이션 캠프 (37)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 인프런
  • MongoDB
  • KOCW
  • JPQL
  • 프로그래머스
  • css
  • ajax
  • 레벨2
  • html
  • 자바
  • leetcode
  • dfs
  • 카카오
  • db
  • OS
  • QueryDSL
  • 생활코딩
  • ORM
  • Java
  • inflearn
  • cs
  • SQL
  • Python
  • API
  • 파이썬
  • spring
  • til
  • JPA
  • Memory
  • JS

최근 댓글

hELLO · Designed By 정상우.v4.2.2
hjkim0502
[ReactJS로 영화 웹 서비스 만들기] Effects
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.