course/nomadcoder
[ReactJS로 영화 웹 서비스 만들기] Effects
hjkim0502
2021. 12. 22. 21:24
- reactjs는 state가 바뀔 때마다 해당 component 전체가 다시 렌더링 됨
-
console.log("call an api")는 한번만 실행하고 싶어도 state 변화할 때마다 다시 실행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> ); }
-
- component 내의 특정 부분(코드)을 state 변화할 때마다 렌더링되지 않게하기 -> useEffect 함수 사용
-
console.log("i run only once")는 state가 바뀌어도 다시 렌더링 되지 않음 (최초 한번만 실행)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;
- 첫 번째 인자(함수)에 선택적으로 렌더링 하고 싶은 코드 삽입
-
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 이후 삽입)
-
component가 삭제될 때에도 원하는 코드 실행 가능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> ); }
-