data:image/s3,"s3://crabby-images/fd111/fd11109fcced934e5ff4c7b29823866f8096d458" alt="React.JS) 4. Cleanup 사용하기"
1. 초기 상태
import { useState, useEffect } from "react"; function App() { return ( <div> </div> ); } export default App;
2. 버튼 만들기
import { useState, useEffect } from "react"; function App() { const [showing, setShowing] = useState(false); const onClick = () => setShowing((prev) => !prev) return ( <div> <button onClick={onClick}>{showing ? "Hide" : "Show"}</button> </div> ); } export default App;
data:image/s3,"s3://crabby-images/e58e9/e58e9629ecbae961b639ed2ef55a3c57633cde4b" alt="notion image"
data:image/s3,"s3://crabby-images/aaa40/aaa40e13012c67c0bdf02458cce173f8e67e3284" alt="notion image"
3. Hello 컴포넌트를 추가하기
import { useState, useEffect } from "react"; function Hello() { 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> ); } export default App;
data:image/s3,"s3://crabby-images/0c643/0c643b4e66b60fa0f82df9f7e9c661a4c4fc5ab7" alt="notion image"
- 클릭 이벤트에 따라 상태가 변경되고 그 상태에 따라 보이고 숨기기
import { useState, useEffect } from "react"; function Hello() { useEffect(() => console.log("im here") , []); 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> ); } export default App;
data:image/s3,"s3://crabby-images/b574e/b574e96f7891fce140450a590e0df222b39304df" alt="notion image"
data:image/s3,"s3://crabby-images/591f8/591f8ed670fc23a71926a2156a44fd689f16a216" alt="notion image"
4. Cleanup
- React의
useEffect
훅에서 사용하는 개념
- 컴포넌트가 언마운트될 때나 특정 상태가 변경될 때 이전에 설정된 리소스를 정리하는 과정
- 언마운트: 컴포넌트가 DOM에서 제거되는 과정
- 이벤트 리스너, 구독 등을 설정한 후, 이러한 리소스를 해제하거나 초기화하기 위해 사용
- 생성되고 없어지는 순간을 알 수 있음
import { useState, useEffect } from "react"; function Hello() { function byFn() { console.log("bye"); } function hiFn() { console.log("created"); return byFn; } useEffect(hiFn, []); 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> ); } export default App;
data:image/s3,"s3://crabby-images/3fd3c/3fd3cadc16f168d478618eb85478b71c12cf5dda" alt="notion image"
data:image/s3,"s3://crabby-images/bd858/bd858e6e38746405a143c54025d968074503fe40" alt="notion image"
- 하나의 함수로 적용하기
import { useState, useEffect } from "react"; function Hello() { 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> ); } export default App;
data:image/s3,"s3://crabby-images/d394e/d394e256a21ec434f37e347501cde482ca60b99c" alt="notion image"
data:image/s3,"s3://crabby-images/3b17c/3b17c941b41468978bc10afdddadf1e106163f30" alt="notion image"
Share article