data:image/s3,"s3://crabby-images/53dbb/53dbb0ee3d9e797a910f5f806c28ad33e62ddceb" alt="React.JS) 5. 간단한 To Do List 만들기"
1. input 태그 만들기
- onChange로 이벤트 연결하여 값 받아오기
import { useState, useEffect } from "react"; function App() { const [toDo, setToDo] = useState(""); const onChange = (event) => setToDo(event.target.value); console.log(toDo); return ( <div> <input onChange={onChange} type="text" placeholder="Write your to do" /> </div> ); } export default App;
data:image/s3,"s3://crabby-images/65cf5/65cf5b1459b18a81076abb9123f6f3794b57eb20" alt="notion image"
2. form 태그의 submit
import { useState, useEffect } from "react"; function App() { const [toDo, setToDo] = useState(""); const onChange = (event) => setToDo(event.target.value); console.log(toDo); return ( <div> <form> <input onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> </div> ); } export default App;
data:image/s3,"s3://crabby-images/205bf/205bf5107158740d0cc6549b61f9c3845cd5a83e" alt="notion image"
data:image/s3,"s3://crabby-images/9f3ec/9f3ecfc33dc042309e3f0b2da389a46370a0573f" alt="notion image"
- submit 막기
import { useState } from "react"; function App() { const [toDo, setToDo] = useState(""); const onChange = (event) => setToDo(event.target.value); const onSubmit = (event) => { event.preventDefault(); console.log(toDo); }; return ( <div> <form onSubmit={onSubmit}> <input value={toDo} onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> </div> ); } export default App;
data:image/s3,"s3://crabby-images/1914d/1914d74353c73c5901ff252b12fe6cfc867f0c81" alt="notion image"
- input 태그가 비어있을때만 submit 막기
import { useState } from "react"; function App() { const [toDo, setToDo] = useState(""); const onChange = (event) => setToDo(event.target.value); const onSubmit = (event) => { event.preventDefault(); if(toDo === "") { return; } setToDo(""); }; return ( <div> <form onSubmit={onSubmit}> <input value={toDo} onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> </div> ); } export default App;
data:image/s3,"s3://crabby-images/cc89f/cc89fb4f28aaf8839756b09a22b9bda9d4fdeca9" alt="notion image"
data:image/s3,"s3://crabby-images/f5ddb/f5ddbc74715a5e18f585c1315d2fa652b540af55" alt="notion image"
3. 배열 만들기
- JS에서 배열에 추가할 때
toDos.push()
- state를 직접 수정할 수 없음
- 함수 이용하기
setToDos(currentArray => [toDo, ...currentArray]); // 새로운 배열로 만들기 setToDo(""); // 비어있는 값으로 셋팅
- 비어있는 배열 생성
import { useState } from "react"; function App() { const [toDo, setToDo] = useState(""); const [toDos, setToDos] = useState([]); const onChange = (event) => setToDo(event.target.value); const onSubmit = (event) => { event.preventDefault(); if(toDo === "") { return; } setToDo(""); }; console.log(toDos); return ( <div> <form onSubmit={onSubmit}> <input value={toDo} onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> </div> ); } export default App;
data:image/s3,"s3://crabby-images/b739d/b739d62f2183210e12be86008cfd3d0f1de88bca" alt="notion image"
- 새로운 배열에 받아오기
import { useState } from "react"; function App() { const [toDo, setToDo] = useState(""); const [toDos, setToDos] = useState([]); const onChange = (event) => setToDo(event.target.value); const onSubmit = (event) => { event.preventDefault(); if(toDo === "") { return; } setToDos(currentArray => [toDo, ...currentArray]); setToDo(""); }; console.log(toDos); return ( <div> <form onSubmit={onSubmit}> <input value={toDo} onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> </div> ); } export default App;
data:image/s3,"s3://crabby-images/ac17c/ac17cc242dc651453bf8c4ae58f95ebfdd8037eb" alt="notion image"
4. To Dos의 갯수 나타내기
import { useState } from "react"; function App() { const [toDo, setToDo] = useState(""); const [toDos, setToDos] = useState([]); const onChange = (event) => setToDo(event.target.value); const onSubmit = (event) => { event.preventDefault(); if(toDo === "") { return; } setToDos(currentArray => [toDo, ...currentArray]); setToDo(""); }; console.log(toDos); return ( <div> <form onSubmit={onSubmit}> <h1>My To Dos ({toDos.length})</h1> <input value={toDo} onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> </div> ); } export default App;
data:image/s3,"s3://crabby-images/46969/46969832ef490a70b3ec00b3604eb5c8bcea3276" alt="notion image"
5. 동적으로 List 만들기
import { useState } from "react"; function App() { const [toDo, setToDo] = useState(""); const [toDos, setToDos] = useState([]); const onChange = (event) => setToDo(event.target.value); const onSubmit = (event) => { event.preventDefault(); if(toDo === "") { return; } setToDos(currentArray => [toDo, ...currentArray]); setToDo(""); }; console.log(toDos); return ( <div> <form onSubmit={onSubmit}> <h1>My To Dos ({toDos.length})</h1> <input value={toDo} onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> <hr /> <ul> {toDos.map((item) => <li>{item}</li>)} </ul> </div> ); } export default App;
data:image/s3,"s3://crabby-images/f07a6/f07a6fadd5b14d27d5f8b32f22b85c9391fa44f2" alt="notion image"
- 리스트를 렌더링할 때 각 요소에 고유한 "key" prop을 지정해야 함
- 고유한 키는 React가 어떤 항목이 변경되었는지, 추가되었는지 또는 제거되었는지를 식별
- 키가 없으면 React가 리스트의 항목을 효율적으로 업데이트할 수 없어서 성능 저하가 발생
data:image/s3,"s3://crabby-images/c5581/c55819b3bdba16b8d7995526cac8bc9dcb5a8779" alt="notion image"
import { useState } from "react"; function App() { const [toDo, setToDo] = useState(""); const [toDos, setToDos] = useState([]); const onChange = (event) => setToDo(event.target.value); const onSubmit = (event) => { event.preventDefault(); if(toDo === "") { return; } setToDos(currentArray => [toDo, ...currentArray]); setToDo(""); }; return ( <div> <form onSubmit={onSubmit}> <h1>My To Dos ({toDos.length})</h1> <input value={toDo} onChange={onChange} type="text" placeholder="Write your to do" /> <button>Add To Do</button> </form> <hr /> <ul> {toDos.map((item, index) => <li key={index}>{item}</li>)} </ul> </div> ); } export default App;
data:image/s3,"s3://crabby-images/3d21b/3d21be24af552f0b4b55ed3494fcd6425834cf42" alt="notion image"
Share article